Hot spot (počítačové programování) - Hot spot (computer programming)

A hot spot v počítačová věda je nejčastěji definována jako oblast a počítačový program kde dochází k vysokému podílu prováděných instrukcí nebo kde je většina času stráveného prováděním programu (nemusí to být nutně totéž, protože některé instrukce jsou rychlejší než jiné).

Pokud je program náhodně zastaven, počítadlo programů (dále jen ukazatel k další instrukci, která má být provedena) je často zjištěno, že obsahuje adresu instrukce v určitém rozsahu, což možná označuje kód, který vyžaduje optimalizaci, nebo dokonce naznačuje existenci „těsného“ procesor smyčka. Tuto jednoduchou techniku ​​lze ve skutečnosti použít jako metodu detekce vysoce používaných instrukcí, i když poněkud sofistikovanější metody, jako např simulátory instrukční sady nebo analyzátory výkonu, dosáhnout toho přesněji a důsledněji.

Historie detekce hot spotů

The počítačový vědec Donald Knuth popsal své první setkání s tím, co označuje jako a skoková stopa v rozhovoru pro Dr. Dobb's Journal v roce 1996, říká:

V 60. letech někdo vymyslel koncept „skokové stopy“. To byl způsob, jak změnit jazyk stroje programu, takže by to změnilo další větev nebo instrukce skoku zachovat si kontrolu, takže můžete program spouštět poměrně vysokou rychlostí namísto interpretace každé instrukce po jedné a zaznamenávat do souboru, kde se program odchýlil od sekvenčnosti. Zpracováním tohoto souboru můžete zjistit, kde program trávil většinu času. První den, kdy jsme měli tento software spuštěný, jsme jej použili na náš Fortran překladač dodáno, předpokládám, že to bylo v té době, Control Data Corporation. Zjistili jsme, že tráví 87 procent svého času čtením komentáře! Důvod byl ten, že se překládal z jednoho kódového systému do druhého do jiného.[1]

Opakování

Výše uvedený příklad slouží k ilustraci, že efektivní detekce horkých míst je často iterativní proces a možná takový, který by měl být proveden vždy (místo toho, abyste jednoduše akceptovali, že program funguje rozumně). Po vyloučení veškerého cizího zpracování (například odstraněním všech vložených komentářů) by nová běhová analýza přesněji detekovala „skutečné“ aktivní body v překladu. Pokud vůbec nedocházelo k detekci horkých míst, program pravděpodobně spotřeboval mnohem více zdrojů, než bylo nutné, možná po mnoho let na mnoha strojích, aniž by si toho někdo byl plně vědom.

Simulace instrukční sady jako detektor horkých míst

An simulátor instrukční sady lze použít k počítání pokaždé, když je provedena konkrétní instrukce, a později k vytvoření buď zobrazení na obrazovce, vytištěného seznamu programů (s počty a / nebo procenty z celkového počtu délka cesty instrukce ) nebo samostatná zpráva, která přesně ukazuje, kde došlo k nejvyššímu počtu pokynů. Toto poskytuje pouze a relativní pohled na horká místa (z pohledu kroku instrukce), protože většina instrukcí má na mnoha strojích různá časování. Poskytuje však míru vysoce používaného kódu a ten, který je sám o sobě docela užitečný při ladění algoritmu.

Viz také

Reference