Deutsch English Français Italiano |
<viacjn$lbe2$1@dont-email.me> View for Bookmarking (what is this?) Look up another Usenet article |
Path: ...!weretis.net!feeder9.news.weretis.net!news.quux.org!eternal-september.org!feeder3.eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail From: Bart <bc@freeuk.com> Newsgroups: comp.lang.c Subject: Re: else ladders practice Date: Thu, 28 Nov 2024 18:25:59 +0000 Organization: A noiseless patient Spider Lines: 77 Message-ID: <viacjn$lbe2$1@dont-email.me> References: <3deb64c5b0ee344acd9fbaea1002baf7302c1e8f@i2pn2.org> <vg37nr$3bo0c$1@dont-email.me> <vg3b98$3cc8q$1@dont-email.me> <vg5351$3pada$1@dont-email.me> <vg62vg$3uv02$1@dont-email.me> <vgd3ro$2pvl4$1@paganini.bofh.team> <vgdc4q$1ikja$1@dont-email.me> <vgdt36$2r682$2@paganini.bofh.team> <vge8un$1o57r$3@dont-email.me> <vgpi5h$6s5t$1@paganini.bofh.team> <vgtsli$1690f$1@dont-email.me> <vhgr1v$2ovnd$1@paganini.bofh.team> <vhic66$1thk0$1@dont-email.me> <vhins8$1vuvp$1@dont-email.me> <vhj7nc$2svjh$1@paganini.bofh.team> <vhje8l$2412p$1@dont-email.me> <86y117qhc8.fsf@linuxsc.com> <vi2m3o$2vspa$1@dont-email.me> <86cyiiqit8.fsf@linuxsc.com> <vi4iji$3f7a3$1@dont-email.me> <86mshkos1a.fsf@linuxsc.com> <vi9ukc$ib2v$1@dont-email.me> <via977$knic$1@dont-email.me> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Injection-Date: Thu, 28 Nov 2024 19:26:00 +0100 (CET) Injection-Info: dont-email.me; posting-host="033a1fb1a70fe4f5596322438ef79f57"; logging-data="699842"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+tkEqWxk/doimd/QaM3DuU" User-Agent: Mozilla Thunderbird Cancel-Lock: sha1:/Zrfd84N0LvxtJ2UJEcqMCOxYF4= In-Reply-To: <via977$knic$1@dont-email.me> Content-Language: en-GB Bytes: 5335 On 28/11/2024 17:28, Janis Papanagnou wrote: > On 28.11.2024 15:27, Bart wrote: >>> [ compilation times ] >> >> And for me, used to decades of sub-one-second response times, 7 seconds >> seems like for ever. [...] > > Sub-seconds is very important in response times of interactive tools; > I recall we've measured, e.g. for GUI applications, the exact timing, > and we've taken into account results of psychological sciences. The > accepted response times for our applications were somewhere around > 0.20 seconds, and even 0.50 seconds was by far unacceptable. > > But we're speaking about compilation times. And I'm a bit astonished > about a sub-second requirement or necessity. I'm typically compiling > source code after I've edited it, where the latter is by far the most > dominating step. And before the editing there's usually the analysis > of code, that requires even more time than the simple but interactive > editing process. You can make a similar argument about turning on the light switch when entering a room. Flicking light switches is not something you need to do every few seconds, but if the light took 5 seconds to come on (or even one second), it would be incredibly annoying. It would stop the fluency of whatever you were planning to do. You might even forget why you needed to go into the room in the first place. When I start the compile all the major time demanding > tasks that are necessary to create the software fix have already been > done, and I certainly don't need a sub-second response from compiler. > > Though I observed a certain behavior of programmers who use tools with > a fast response time. Since it doesn't cost anything they just make a > single change and compile to see whether it works, and, rinse repeat, > do that for every _single_ change *multiple* times. Well, what's wrong with that? It's how lots of things already work, by doing things incrementally. If recompiling an entire program of any size really was instant, would you still work exactly the same way? People find scripting languages productive, partly because there is no discrete build step. > My own programming > habits got also somewhat influenced by that, though I still try to fix > things in brain before I ask the compiler what it thinks of my change. > This is certainly influenced by the mainframe days where I designed my > algorithms on paper, punched my program on a stack of punch cards, and > examined and fixed the errors all at once. I also remember using punched cards at college. But generally it was using an interactive terminal. Compiling and linking were still big deals when using mini- and mainframe computers. Oddly, it was only using tiny, underpowered microprocessor systems, that I realised how fast language tools really could be. At least the ones I wrote. Those ported from bigger computers would take minutes for the simplest program, as I later found. Mine took seconds or fraction of a second. Part of that was down to using a resident compile/IDE that kept things in memory as much as possible, since floppy disks were slow. Here's a test: how many times can you twiddle your thumbs while waiting for something to build? (That is, put your hands together with interlocked fingers, and rotate your thumbs around each other). I can only manage 3-4 - if building an artificial 1Mloc benchmark. Otherwise it's impossible to even put my hands together. In 7 seconds I can do nearly 25 twiddles. That's a really useful use of my time!