- Feature Articles
-
CodeSOD
- Most Recent Articles
- Irritants Make Perls
- Crossly Joined
- My Identification
- Mr Number
- intint
- Empty Reasoning
- Zero Competence
- One Month
-
Error'd
- Most Recent Articles
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Three Little Nyms
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
i done worked with inline assembly all my life, yessir
i tell you what
Admin
It's......it's brilliant.
Admin
On the other hand, it's a great way to keep a PHB happy...
Admin
Speed Loops... BRILLIANT!
I guess that's what happens when you need to "fill the void"
Admin
That's...pretty crummy. If they would have put as much effort into creating the GUI as they did avoiding work, then we might have had a real alternative to Microsoft.
Admin
Wayne is a goddamn genius.
I do something similar at by giving out really long timelines for development and then consistently beating them by huge margins. This also gives me the benefit of extra time if something needs more work than I planned.
Admin
I feel dumb. I can't find the integer overflow. :(
char *p only goes up to 0x0010423F which is far below the maximum of 0xFFFFFFFF.
and int i only goes up to 0x000F423F which is also below the maximum of 0x7FFFFFFF.
The only WTFs I see are a hardcoded memory address, which I suppose could be acceptable depending on what hardware and operating system the code is run under, and the setting of 1000000 bytes to 0 when there's probably a better way to do it (memset is one) although what improvements can be made depends on how the set memory is used (if it is later read without setting and the program depends on 0 for initial values then there's probably no way around it).
[Edit: Wait... it makes more sense if those were int16s... were they?]
Admin
That is brilliant.
Really. I'm in awe, this guy is a genius.
Admin
I thought the 80/20 rule was: The first 80% of the project take 20% of your time, the last 20% of the project takes 80% of the time. But I remember it as the 90/10 rule.
Admin
In more or less every DOS compiler you'll find, int defaults to short, aka a 16-bit integer. 0x000F423F > 0xFFFF
Admin
Building in future optimizations is a pretty standard technique. In certain organizations you simply have to prepare for defending yourself.
Very similar to hardware engineers who purposely design in expensive components, knowing they'll be asked to go through a cost reduction phase later.
No WTF here; just sensible self-defense.
Admin
ints were probably only two-byte words back in 1989. int i could only have gone up to 32767.
Admin
I thought 80/20 was how to completely bullshit situations: when you need a percentage, use either 80 or 20 percent as your number. E.g. : "80 % of this department is slacking off," "20% of companies give free soda to their employees," "20% of experts say YO MAMA."
Admin
Correct, which in the days of Windows 2, they most definitely were.
Admin
Don't forget it's 1987.
Wayne is a Genius. Where is he working now? Can I apply?
Admin
oh wait, that would be three months after 1986 not 1989, hang on...
Don't forget it's 198L
Admin
At last!
Finally, an explanation of why Lotus Notes is so &^%@&$ SLOW!!!
Admin
I had a uni lecturer explain how we should do things like this. He said it was great as a contractor as he'd get calls back from past clients asking if he could update their system to run faster, he'd do the same thing as the OP said; shorten some un-necessary purposefully placed loop, say it took 6+ hours doing it and voila, instant pay day.
Admin
Wow. What a BOFH, or perhaps a BPFH.
Admin
I worked on a large consumer application that's on at least version 12 now. The code is sprinkled with sleep(10000) everywhere. Some were hold-overs from past days when you were waiting for a supposed synchronous hardware operation to complete, other times it was because the original programmer didn't understand multi-threading and IPC, so the sleep was to let another thread finish an operation or avoid hammering on a shared resource. Our 'Architect' would regularly go back and reduce the numbers and claim wonderful improvements in how fast the program now ran. Alas, his name wasn't Wayne.
Admin
I thought the 80/20 rule was: The first 20% of the project takes 80% of the allotted time, while the remaining 80% of the project takes another 80% of the allotted time.
The big flaw I see to their speed-up loops is that they should have made the ending value a parameter read in from a config file or something of the sort. Then you wouldn't have to recompile to change the delay. Also, it really should check the system clock rather than just counting. That way you'd get consistent performance savings regardless of the speed of the processor.
Admin
I've done that myself, and it's still in production. The client complained that he couldn't see the little animated widget I'd put in for the AJAX call, so I added a .5 second delay on the server side of the AJAX call. Result, happy (but stupid) client.
Admin
uh, wouldn't the compiler optimize that away? i mean, depending on the intelligence of the compiler...
Admin
Can't quite figure out why the last contractor "just left all of a sudden." Did he decide he wanted a real job instead?
Admin
not back then, optimization is a quite new field
Admin
Wayne and Wane really need to work out their split personality issues.
Admin
Oh, i've done that. Someone complained that sometimes, saving a file was to fast, so he didn't know if it was succesfull, since the statusbar popped in and out to fast.
Solution: If filesize < 2mb open FakeSaveAnimation.gif end
Admin
The funny for me was the google ad on this exact page:
"Slow computer? Speed it up by cleaning your registry..." maybe there is some NumberOfZerosInSpeedupLoop in Windows registry?
Admin
I read statements like this again and again, but I'll be damned if I've ever seen a compiler do that. Ok, ok, I've only used the compiler that comes with (various versions of) Visual C++ but it is supposed to optimize some and even with full optimizations on in a release build it's never optimized anything like this away that I've found.
Admin
Isn't the 80/20 rule... 80% of the work is done by 20% of the people? No wait, I'm thinking of the 90/10 rule.
Admin
It will optimize it away. If you just set to Release mode in Visual Studio, that isn't full optimizations. You need to tell it that you want it to run as fast as possible too.
One time, I tried something like this:
while (true);
Set the mode to Release and the optimizations to "Speed" and voila, program runs, no infinite loop.
Back in the late 80s though, there probably weren't optimizations like this so that for loop would have happily done nothing... 1000000 times.
Admin
Disassembly (from Lutz Roeder's .NET Reflector):
Admin
Apparently giving the user a 'save complete' message was too much hassle?
Admin
What you mentioned is not an optimization, it's a breaking change. Removing an infinite loop is not a speed-up, it's a major semantic change. Just imagine you had put "DeleteAllFilesInUsersHomeDir();" after the loop.
Visual C++ is notorious for "optimizing" code in ways that break it. I encountered such cases myself and have seen co-workers run into similar issues where the Debug code ran fine and the Release version screwed up big time and disabling some optimizations resolved these issues.
Admin
WRONG!!!
Admin
Ummm its the other way around.
Admin
Admin
There's no optimization the compiler could do there. Removing the for loop would change the behavior of the program (by not printing out the "Hello World!"). If you removed the WriteLine, then it should remove the loop.
Admin
Integer overflow!? How is that the "obvious" error? He had me at *p = 0x10000;. I'm sorry, but if you're picking an arbitrary memory address and writing 1 million zeros starting at that point, the LEAST of your problems will be the integer overflow of i. Hell, in a system like DOS, you may not even make it to the point of overflowing i before the system hangs because you wrote over some video buffer or something.
Admin
TRWTF is that the article has 2^10 words.
Admin
No, it wouldn't. In either case, "Hello World!" is printed exactly once.
Admin
Probably because that loop actually does something?
Admin
WRONG TAKE 2!!!
Same code compiled in Visual C++ 6
Admin
That is a WTF? No
That's a GREAT IDEA
Admin
No, the program only prints out "Hello World!" once, after the loop. Notice the ";" at the end of "for (int i = 0; i < 100000; i++) ;", that is, as the disassembly showed, an empty loop body, equivalent to "{ }".
Besides, even with the "Console.WriteLine("Hello World!");" removed (commented out), the disassembly becomes:
The loop still remains.
Admin
I really hope none of you guys work for Microsoft.
Admin
What? I've done some video programming under DOS and if there was a memory area with fixed address that you wanted to overwrite with zeroes, it was the video RAM. And no, the system would not hang if you did this.
The system would rather hang (or probably crash in a more spectacular way) if you overwrote some hardware interrupt handler or some code/data structures used by such a handler. You could prevent that by executing CLI before the loop. Of course that would only make any sense if you wanted to kick DOS from memory altogether, for example to load your own OS instead.
Admin
It's amazing how many people don't understand the C# syntax although in the case of this loop, it's absolutely identical to that of C or C++.
This is a loop whose body consists of the empty statement. It has no effect on program semantics.
Admin
The point was not that the loop was infinite; it was that the loop did nothing. Consider:
someThreadVariable = 400;
while (someThreadVariable != 500);
DeleteAllFilesInUsersHomeDir();
If we aren't careful with threading, someThreadVariable could be changed by another thread. So the current thread should "pause" until the other thread changes the variable to 500.
If you run this in debug mode, it will work as you would expect. If you turn on optimizations, Visual Studio will see this as a loop that does nothing and remove it and the "pause" that we would expect is gone.
NOTE: I am not saying that this type of coding is a good idea! It's just an example!!
Admin
It's not pretend-to-be-a-time-traveler day. You must really be a time traveller.