MasterOne, 2014-03-23 17:32 »
If you missed it, below is the writing of a Microsoft employee that came across as extremely pissed at the company. Subsequent to deflating, he did an about face and recants his earlier statements in another post. It's evident to me that Microsoft only fixes and adds features to Windows if it helps their bottom line. I've done comparison tests between various recent Linux distros and Windows 7, and the Linux system always is noticeably more snappy and responsive. It's just faster. Since NTFS still can't compete with EXT4, and as you'll read below, ReFS sounds like a dumb idea, I'm not going to waste my time testing 8.1. I have ran it before, and it was adequately responsive. But, as you all know, I don't run OS's with backdoors in them with unknown potential and undocumented functionality. And even if it were documented and its potential were known, I still wouldn't use it. Windows needs a package management system just like Linux has, and i'm not talking about the feudalistic app store that's designed for a 4 year old. Linux and Apache HTTP Server have taken the web server market by storm, and it's not just because it's free that this happened. It's just better. Apache is simple to set up; it only requires configuring a file in vi or nano, and you are up and running in no time. Debian distros have a few files to configure instead of 1, but it's still very easy. I'm really disappointed in Microsoft, and I still can't believe how stupid their management team is. They are just totally clueless, and have no idea on how to get their products moving again. Here's a tip to start: Stop using the name "Windows". It's stupid, lame, and has a negative connotation associated with it. "Windows" may have been cool in 1985 when GUI's were cool, but it's not cool anymore. Slowly migrate to something else, and don't name it anything like "Bing" or "Zune". Microsoft obviously has idiots working for it that choose names.
Think of all the people that got burned by Windows 8. Are they going to continue buying Microsoft's crappy operating systems next time around, as the desktop market shrinks? Linux is getting better and better, and maybe one day Apple will open up their software to the PC market. Who knows. There are so many other options now for computer users, that if they continue having poor experiences with Microsoft products, they're going to abandon them completely. And let me reiterate -- the fucking desktop market is shrinking, so is that not a double whammy? Your market is shrinking,
and the users are running away from that shrinking market because your products are shit. The desktop market is shrinking, and your operating systems are stinking. Seriously, I can't believe that Windows still isn't right, and it's been since 1985. Wow.
I'm a developer in Windows and contribute to the NT kernel. (Proof: the SHA1 hash of revision #102 of [Edit: filename redacted] is [Edit: hash redacted].) I'm posting through Tor for obvious reasons.
Windows is indeed slower than other operating systems in many scenarios, and the gap is worsening. The cause of the problem is social. There's almost none of the improvement for its own sake, for the sake of glory, that you see in the Linux world.
Granted, occasionally one sees naive people try to make things better. These people almost always fail. We can and do improve performance for specific scenarios that people with the ability to allocate resources believe impact business goals, but this work is Sisyphean. There's no formal or informal program of systemic performance improvement. We started caring about security because pre-SP3 Windows XP was an existential threat to the business. Our low performance is not an existential threat to the business.
See, component owners are generally openly hostile to outside patches: if you're a dev, accepting an outside patch makes your lead angry (due to the need to maintain this patch and to justify in in shiproom the unplanned design change), makes test angry (because test is on the hook for making sure the change doesn't break anything, and you just made work for them), and PM is angry (due to the schedule implications of code churn). There's just no incentive to accept changes from outside your own team. You can always find a reason to say "no", and you have very little incentive to say "yes".
There's also little incentive to create changes in the first place. On linux-kernel, if you improve the performance of directory traversal by a consistent 5%, you're praised and thanked. Here, if you do that and you're not on the object manager team, then even if you do get your code past the Ob owners and into the tree, your own management doesn't care. Yes, making a massive improvement will get you noticed by senior people and could be a boon for your career, but the improvement has to be very large to attract that kind of attention. Incremental improvements just annoy people and are, at best, neutral for your career. If you're unlucky and you tell your lead about how you improved performance of some other component on the system, he'll just ask you whether you can accelerate your bug glide.
Is it any wonder that people stop trying to do unplanned work after a little while?
Another reason for the quality gap is that that we've been having trouble keeping talented people. Google and other large Seattle-area companies keep poaching our best, most experienced developers, and we hire youths straight from college to replace them. You find SDEs and SDE IIs maintaining hugely import systems. These developers mean well and are usually adequately intelligent, but they don't understand why certain decisions were made, don't have a thorough understanding of the intricate details of how their systems work, and most importantly, don't want to change anything that already works.
These junior developers also have a tendency to make improvements to the system by implementing brand-new features instead of improving old ones. Look at recent Microsoft releases: we don't fix old features, but accrete new ones. New features help much more at review time than improvements to old ones.
(That's literally the explanation for PowerShell. Many of us wanted to improve cmd.exe, but couldn't.)
More examples:
We can't touch named pipes. Let's add %INTERNAL_NOTIFICATION_SYSTEM%! And let's make it inconsistent with virtually every other named NT primitive.
We can't expose %INTERNAL_NOTIFICATION_SYSTEM% to the rest of the world because we don't want to fill out paperwork and we're not losing sales because we only have 1990s-era Win32 APIs available publicly.
We can't touch DCOM. So we create another %C#_REMOTING_FLAVOR_OF_THE_WEEK%!
XNA. Need I say more?
Why would anyone need an archive format that supports files larger than 2GB?
Let's support symbolic links, but make sure that nobody can use them so we don't get blamed for security vulnerabilities (Great! Now we get to look sage and responsible!)
We can't touch Source Depot, so let's hack together SDX!
We can't touch SDX, so let's pretend for four releases that we're moving to TFS while not actually changing anything!
Oh god, the NTFS code is a purple opium-fueled Victorian horror novel that uses global recursive locks and SEH for flow control. Let's write ReFs instead. (And hey, let's start by copying and pasting the NTFS source code and removing half the features! Then let's add checksums, because checksums are cool, right, and now with checksums we're just as good as ZFS? Right? And who needs quotas anyway?)
We just can't be fucked to implement C11 support, and variadic templates were just too hard to implement in a year. (But ohmygosh we turned "^" into a reference-counted pointer operator. Oh, and what's a reference cycle?)
Look: Microsoft still has some old-fashioned hardcore talented developers who can code circles around brogrammers down in the valley. These people have a keen appreciation of the complexities of operating system development and an eye for good, clean design. The NT kernel is still much better than Linux in some ways --- you guys be trippin' with your overcommit-by-default MM nonsense --- but our good people keep retiring or moving to other large technology companies, and there are few new people achieving the level of technical virtuosity needed to replace the people who leave. We fill headcount with nine-to-five-with-kids types, desperate-to-please H1Bs, and Google rejects. We occasionally get good people anyway, as if by mistake, but not enough. Is it any wonder we're falling behind? The rot has already set in.
If you missed it, below is the writing of a Microsoft employee that came across as extremely pissed at the company. Subsequent to deflating, he did an about face and recants his earlier statements in another post. It's evident to me that Microsoft only fixes and adds features to Windows if it helps their bottom line. I've done comparison tests between various recent Linux distros and Windows 7, and the Linux system always is noticeably more snappy and responsive. It's just faster. Since NTFS still can't compete with EXT4, and as you'll read below, ReFS sounds like a dumb idea, I'm not going to waste my time testing 8.1. I have ran it before, and it was adequately responsive. But, as you all know, I don't run OS's with backdoors in them with unknown potential and undocumented functionality. And even if it were documented and its potential were known, I still wouldn't use it. Windows needs a package management system just like Linux has, and i'm not talking about the feudalistic app store that's designed for a 4 year old. Linux and Apache HTTP Server have taken the web server market by storm, and it's not just because it's free that this happened. It's just better. Apache is simple to set up; it only requires configuring a file in vi or nano, and you are up and running in no time. Debian distros have a few files to configure instead of 1, but it's still very easy. I'm really disappointed in Microsoft, and I still can't believe how stupid their management team is. They are just totally clueless, and have no idea on how to get their products moving again. Here's a tip to start: Stop using the name "Windows". It's stupid, lame, and has a negative connotation associated with it. "Windows" may have been cool in 1985 when GUI's were cool, but it's not cool anymore. Slowly migrate to something else, and don't name it anything like "Bing" or "Zune". Microsoft obviously has idiots working for it that choose names.
Think of all the people that got burned by Windows 8. Are they going to continue buying Microsoft's crappy operating systems next time around, as the desktop market shrinks? Linux is getting better and better, and maybe one day Apple will open up their software to the PC market. Who knows. There are so many other options now for computer users, that if they continue having poor experiences with Microsoft products, they're going to abandon them completely. And let me reiterate -- the fucking desktop market is shrinking, so is that not a double whammy? Your market is shrinking, [b]and[/b] the users are running away from that shrinking market because your products are shit. The desktop market is shrinking, and your operating systems are stinking. Seriously, I can't believe that Windows still isn't right, and it's been since 1985. Wow.
[quote] I'm a developer in Windows and contribute to the NT kernel. (Proof: the SHA1 hash of revision #102 of [Edit: filename redacted] is [Edit: hash redacted].) I'm posting through Tor for obvious reasons.
Windows is indeed slower than other operating systems in many scenarios, and the gap is worsening. The cause of the problem is social. There's almost none of the improvement for its own sake, for the sake of glory, that you see in the Linux world.
Granted, occasionally one sees naive people try to make things better. These people almost always fail. We can and do improve performance for specific scenarios that people with the ability to allocate resources believe impact business goals, but this work is Sisyphean. There's no formal or informal program of systemic performance improvement. We started caring about security because pre-SP3 Windows XP was an existential threat to the business. Our low performance is not an existential threat to the business.
See, component owners are generally openly hostile to outside patches: if you're a dev, accepting an outside patch makes your lead angry (due to the need to maintain this patch and to justify in in shiproom the unplanned design change), makes test angry (because test is on the hook for making sure the change doesn't break anything, and you just made work for them), and PM is angry (due to the schedule implications of code churn). There's just no incentive to accept changes from outside your own team. You can always find a reason to say "no", and you have very little incentive to say "yes".
There's also little incentive to create changes in the first place. On linux-kernel, if you improve the performance of directory traversal by a consistent 5%, you're praised and thanked. Here, if you do that and you're not on the object manager team, then even if you do get your code past the Ob owners and into the tree, your own management doesn't care. Yes, making a massive improvement will get you noticed by senior people and could be a boon for your career, but the improvement has to be very large to attract that kind of attention. Incremental improvements just annoy people and are, at best, neutral for your career. If you're unlucky and you tell your lead about how you improved performance of some other component on the system, he'll just ask you whether you can accelerate your bug glide.
Is it any wonder that people stop trying to do unplanned work after a little while?
Another reason for the quality gap is that that we've been having trouble keeping talented people. Google and other large Seattle-area companies keep poaching our best, most experienced developers, and we hire youths straight from college to replace them. You find SDEs and SDE IIs maintaining hugely import systems. These developers mean well and are usually adequately intelligent, but they don't understand why certain decisions were made, don't have a thorough understanding of the intricate details of how their systems work, and most importantly, don't want to change anything that already works.
These junior developers also have a tendency to make improvements to the system by implementing brand-new features instead of improving old ones. Look at recent Microsoft releases: we don't fix old features, but accrete new ones. New features help much more at review time than improvements to old ones.
(That's literally the explanation for PowerShell. Many of us wanted to improve cmd.exe, but couldn't.)
More examples:
We can't touch named pipes. Let's add %INTERNAL_NOTIFICATION_SYSTEM%! And let's make it inconsistent with virtually every other named NT primitive.
We can't expose %INTERNAL_NOTIFICATION_SYSTEM% to the rest of the world because we don't want to fill out paperwork and we're not losing sales because we only have 1990s-era Win32 APIs available publicly.
We can't touch DCOM. So we create another %C#_REMOTING_FLAVOR_OF_THE_WEEK%!
XNA. Need I say more?
Why would anyone need an archive format that supports files larger than 2GB?
Let's support symbolic links, but make sure that nobody can use them so we don't get blamed for security vulnerabilities (Great! Now we get to look sage and responsible!)
We can't touch Source Depot, so let's hack together SDX!
We can't touch SDX, so let's pretend for four releases that we're moving to TFS while not actually changing anything!
Oh god, the NTFS code is a purple opium-fueled Victorian horror novel that uses global recursive locks and SEH for flow control. Let's write ReFs instead. (And hey, let's start by copying and pasting the NTFS source code and removing half the features! Then let's add checksums, because checksums are cool, right, and now with checksums we're just as good as ZFS? Right? And who needs quotas anyway?)
We just can't be fucked to implement C11 support, and variadic templates were just too hard to implement in a year. (But ohmygosh we turned "^" into a reference-counted pointer operator. Oh, and what's a reference cycle?)
Look: Microsoft still has some old-fashioned hardcore talented developers who can code circles around brogrammers down in the valley. These people have a keen appreciation of the complexities of operating system development and an eye for good, clean design. The NT kernel is still much better than Linux in some ways --- you guys be trippin' with your overcommit-by-default MM nonsense --- but our good people keep retiring or moving to other large technology companies, and there are few new people achieving the level of technical virtuosity needed to replace the people who leave. We fill headcount with nine-to-five-with-kids types, desperate-to-please H1Bs, and Google rejects. We occasionally get good people anyway, as if by mistake, but not enough. Is it any wonder we're falling behind? The rot has already set in. [/quote]