Portál AbcLinuxu, 1. května 2025 07:04
Kdysi dávno jsem byl v konferencích cecko@pandora.cz a os@pandora.cz. Už nevím, do které z nich kdosi poslal kus kódu v céčku, který řadu přítomných udivil. Jednalo se o Duff's device, které by se ale mělo jmenovat spíš Hell device. Po letech jsem na tuto konstrukci znovu narazil, tak se s vámi chci podělit
O co jde? Je to kus kódu, kde je konstrukce switch
promíchána s jinou konstrukcí - v tomto případě do/while
. A je to validní céčkový zdroják.
switch (count % 8) /* count > 0 assumed */ { case 0: do { *to++ = *from++; case 7: *to++ = *from++; case 6: *to++ = *from++; case 5: *to++ = *from++; case 4: *to++ = *from++; case 3: *to++ = *from++; case 2: *to++ = *from++; case 1: *to++ = *from++; } while ((count -= 8) > 0); }
K čemu je to dobré? Dnes k ničemu. Ale v 80. letech se dělaly optimalizace na zmenšení počtu větvení programu, takže výše uvedený kód byl rychlejší než:
do { /* count > 0 assumed */ *to++ = *from++; } while (--count > 0);
Dneska už jsou procesory někde jinde, zrychlení to nepřinese. A programátoři takhle už optimalizovat neumí - za vše mluví, že když jsem si psal na tohle benchmark, vyrobil jsem Segmentation Fault. Jdu zase Pythonit.
Tiskni
Sdílej:
1. Pokud by taková optimalizace skutečně pomohla, měl by ji dělat překladač, ne programátor. Takhle zprasit a znečitelnit zdroják kvůli drobnému zrychlení, to nejsem při nejlepší vůli ochoten považovat za chvályhodné.
2. Současné verze GCC (a nejspíš i jiných překladačů) mají funkce typu memcpy()
implementované jako builtin, který už je optimalizován pro danou platformu.
3. Až někdy nebudu mít do čeho dloubnout, docela rád se podívám, jestli je to syntakticky opravdu v pořádku nebo jestli je to jen nepozornost překladače.
memcpy()
. do { /* count > 0 assumed */ *to = *from++; /* Note that the to pointer is NOT incremented */ } while (--count > 0);Tedy neinkrementuje pointer
to
. Čuměl jsem na to jak puk, a myslel jsem, že ostatní čtenáři by čuměli taky. Pak jsem si přečetl, že na adrese to
je namapován I/O port a rozsvítilo se mi. Takže původní verze sice nelze smést ze stolu tvrzením "použij memcpy", ale zato je dnes zcela dokonale pasé. I když jednou jsem v nějaké embedded krabičce na port takhle přistupoval...
Kdysi dávno jsem byl v konferencích cecko@pandora.cz a os@pandora.cz.A proč už nečteš OS? Nedávno jsme tam probírali, jestli by náhodou kluci od Flexu nechtěli to svoje dítko opensourcovat
Tento hustý kousek kódu mě zaujal natolik, že jsem udělal malý benchmark.
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.