www.wikidata.uk-ua.nina.az
Kompilya tor angl Compiler vid angl to compile zbirati v cile komp yuterna programa abo yih nabir sho peretvoryuye kompilyuye vihidnij kod napisanij pevnoyu movoyu programuvannya vihidna mova angl source language na semantichno ekvivalentnij kod v inshij movi programuvannya cilova mova angl target language yakij zazvichaj neobhidnij dlya vikonannya programi mashinoyu napriklad komp yuterom V SRSR zokrema v Ukrayini z 1952 roku do seredini 1960 h rokiv vikoristovuvavsya termin programuvalna programa PP Korotko kompilyator mozhna viznachiti yak programu abo tehnichnij zasib sho vikonuye kompilyaciyu Istorichno kompilyatorom nazivalas programa sho zv yazuvala pidprogrami chim i zumovleno pohodzhennya slova Sogodni ce zavdannya vikonuye komponuvalnik Dlya vikonannya programa ne zavzhdi povinna buti perekladena kompilyatorom isnuye takozh inshij princip pokrokove vikonannya programnih instrukcij interpretatorom Zmist 1 Istoriya rozvitku 2 Proces kompilyaciyi 2 1 Analiz front end 2 1 1 Leksichnij rozbir 2 1 2 Sintaksichnij analiz 2 1 3 Semantichnij analiz 2 1 4 Generator promizhnogo kodu 2 2 Sintez back end 2 2 1 Poperednij analiz promizhnogo kodu 2 2 2 Optimizaciya promizhnogo kodu 2 2 3 Generaciya cilovogo kodu programi 3 Vidi kompilyatoriv 4 Strategiyi kompilyaciyi 5 Vidomi kompilyatori 5 1 Generatori analizatoriv 6 Literatura 7 PosilannyaIstoriya rozvitku RedaguvatiTermin kompilyator vpershe z yavivsya na pochatku 50 h rokiv koli pochala formuvatisya potreba pidvishennya produktivnosti programistiv shlyahom zaprovadzhennya visokorivnevih mov programuvannya Vid pochatku komp yuterni programi pisali na asembleri nizkorivnevij aparatno zalezhnij movi Zi zbilshennyam rozmiru pam yati pervisnih komp yuteriv vinikali novi mozhlivosti dlya optimizaciyi procesu stvorennya program i perehodu na sutnosti vishogo rivnya Avtorom pershogo kompilyatora vvazhayetsya Grejs Goper yaka u 1952 roci stvorila kompilyator dlya movi A 0 Sistema 1 Cej kompilyator yavlyav soboyu okremij pristrij yakij pri zavantazhenni program do operativnoyi pam yati komp yutera bez vikoristannya procesora perekodovuvav programu u mnemonichnih kodah asembleri u dvijkovi programni kodi Tomu cej pershij kompilyator funkcionuvav yak zavantazhuvach ta komponuvalnik ta jogo skladno vidnesti do kompilyatora u suchasnomu rozuminni cogo terminu Pershimi kompilyatorami buli programuvalni programi PP 1 1954 rik ta PP 2 1955 rik yaki buli realizovani na EOM Strila v Moskvi Pershij v sviti kompilyator universalnoyi movi programuvannya visokogo rivnya Adresnoyi movi programuvannya 1955 r z oposeredkovanoyu adresaciyeyu vkazivnikami ye Programuyucha Programa Adresnoyi movi dlya EOM Kiyiv PP AK 2 3 ta PP 2 1955 Adresnoyi movi programuvannya bula realizovana pid riznimi platformami zokrema komp yuteri M 20 BESM 3 BESM 4 Ural Dnipro Minsk 2 3 tosho Kompilyatori Adresnoyi movi programuvannya pisalis na tak zvanij idealnij adresnij obchislyuvalnij mashini IAOM 2 3 yaka ye bazovoyu chastinoyu pidmnozhinoyu Adresnoyi movi programuvannya Oskilki Adresna mova programuvannya 1955 r malo vidoma zakordonom to chasto pomilkovo vvazhayut avtorami pershogo v sviti povnocinnogo kompilyatora komandu rozrobki movi programuvannya Fortran na choli z Dzhonom Bakusom yaka predstavila vinahid u 1957 roci U 1960 roci buv predstavlenij kompilyator movi programuvannya Kobol yakij tezh mav mozhlivist kompilyuvati programi pid rizni platformi Pomilkovo vvazhayut sho kompilyator movi programuvannya Lisp 1962 roku buv pershim kompilyatorom napisanim movoyu dzherela kompilyaciyi oskilki pro tehnologiyu rozrobki kompilyatoriv Adresnoyi movi programuvannya 3 malo komu vidomo Vidtodi napisannya kompilyatora na movi yaku vin kompilyuye stalo poshirenoyu praktikoyu vidomimi prikladami yakoyi stali movi programuvannya S i Paskal Proces kompilyaciyi RedaguvatiProces u yakomu kompilyator chitaye zapisanu pochatkovoyu movoyu programu ta zapisuye cilovoyu movoyu nazivayut kompilyaciyeyu translyaciyeyu perekladom Zalezhno vid tipu kompilyatora ta nalashtuvan cej proces mozhe buti yak prostim odnoprohidnim zchituvannyam i zapisom rezultatu tak i rozgaluzhenoyu bagatokrokovoyu resursomistkoyu obrobkoyu j analizom vhidnogo kodu dlya chislennih optimizacij ta nalashtuvan Zagalom kompilyaciyu podilyayut na taki poslidovni ta zalezhni kroki Analiz front end zchituvannya ta rozbittya pochatkovoyi programi na skladovi chastini dlya stvorennya promizhnogo predstavlennya Leksichnij analiz na comu etapi poslidovnist simvoliv sircevogo fajlu peretvoryuyetsya v poslidovnist leksem Sintaksichnij analiz pid chas yakogo poslidovnist leksem peretvoryuyetsya v derevo rozboru Semantichnij analiz perevirka vidpovidnosti pravilam vhidnoyi movi ta pobudova tablici simvoliv Generator promizhnogo kodu buduye promizhne predstavlennya dlya podalshih optimizacij Sintez back end pobudova cilovoyi programi na bazi promizhnogo predstavlennya Poperednij analiz promizhnogo predstavlennya na zalezhnosti potik danih ta inshi kontekstni vlastivosti vazhlivi dlya optimizaciyi Optimizaciya pokrashennya dlya shvidkodiyi rozmiru paralelizmu tosho Generator cilovogo kodu stvoryuye kincevij rezultat roboti kompilyatora cilovu programu U konkretnih realizaciyah kompilyatoriv ci etapi mozhut buti rozdileni abo navpaki poyednani v tomu chi inshomu viglyadi Pochatkova mova viznachayetsya yiyi sintaksisom opisom togo z yakih konstrukcij skladayetsya mova ta semantikoyu naborom pravil sho viznachayut sut cih konstrukcij Analiz front end Redaguvati Protyagom analizu abo pochatkovoyi stadiyi front end programu rozbivayut na chastini na yaki nakladayetsya gramatichna struktura Nastupnim krokom na bazi ciyeyi strukturi stvoryuyut promizhne predstavlennya programi Vazhlivimi elementami analizu ye viyavlennya sintaksichnih pomilok ta semantichnih nevidpovidnostej yaki vidobrazhaye kompilyator Takozh protyagom fazi analizu zbirayetsya informaciya do tablici simvoliv klyuchovoyi dlya fazi komponuvannya Do fazi analizu zachislyuyut leksichnij sintaksichnij ta semantichnij analizi ta fazu generaciyi promizhnogo kodu 4 Leksichnij rozbir Redaguvati Dokladnishe Leksichnij analizLeksichnij rozbir vidilyayut dlya sproshennya pobudovi kompilyatora Ce linijne skanuvannya vhidnoyi programi pri yakomu simvoli grupuyut v tokeni poslidovnosti simvoliv sho mayut pevne sukupne znachennya Nastupnij ryadok movoyu Paskal len 3 14 r skladayetsya z takih tokeniv Identifikator len Simvol prisvoyennya Chislova stala 3 14 Znak mnozhennya Identifikator r Rozdilnik operatoriv Sintaksichnij analiz Redaguvati Dokladnishe Sintaksichnij analizPoslidovnist mashinnih simvoliv yaki utvoryuyut token nazivayut leksemoyu tokena Tokeni mayut tip napriklad identifikator chislova stala ce tipi tokeniv Deyaki tokeni mayut leksichne znachennya napriklad znachennya chislovoyi chi ryadkovoyi konstanti utvorenoyi z leksemi tokena Zavdannya leksichnogo analizatora viokremiti leksemi tokeniv i povidomiti sintaksichnij analizator pro tip tokena ta jogo leksichne znachennya Iyerarhichnij analiz nazivayut rozborom angl parsing chi sintaksichnim analizom u hodi yakogo vidbuvayetsya grupuvannya tokeniv programi V sintaksichnomu analizi simvolom nazivayut tokeni terminali ta grupi tokeniv ob yednanih u logichne cile v procesi analizu neterminali Sintaksis zvichajno viznachayetsya kontekstno nezalezhnoyu gramatikoyu sho skladayetsya z simvoliv terminaliv i neterminaliv startovogo simvolu sho nalezhit mnozhini neterminaliv ta kontesktno nezalezhnih produkcij Programa ye poslidovnistyu terminaliv yaku mozhna vivesti zi startovogo simvolu poslidovno zastosovuyuchi pravila vivodu produkciyi Produkciya ce zamina poslidovnosti simvoliv S1 na poslidovnist simvoliv S2 Poznachayetsya S1 S2 abo S1 gt S2 Produkciya nazivayetsya kontekstno nezalezhnoyu yaksho S1 odin simvol Zazvichaj rozglyadayut lishe kontekstno nezalezhni produkciyi Zadacha sintaksichnogo analizatora vstanoviti shlyah yakim vhidna programa vivoditsya zi startovogo simvolu Napriklad nastupna gramatika iz troh produkcij opisuye virazi expression sho mozhut skladatis z identifikatoriv identifier chisel number i znaku dodavannya expression identifier expression number expression expression expression Pershij ryadok oznachaye sho bud yakij identifikator ye virazom Drugij ryadok oznachaye sho bud yake chislo ye virazom Tretij ryadok oznachaye sho bud yaka poslidovnist z dvoh viraziv rozdilenih znakom dodavannya tezh ye virazom V cij gramatici simvolami ye expression number identifier ta Expression ye startovim simvolom i neterminalom reshta simvoliv ye terminalami Semantichnij analiz Redaguvati Na bazi sintaksichnogo dereva semantichnij analizator pereviryaye vhidnu programu na vidpovidnist pravilam i viznachennyam movi programuvannya Vazhlivoyu chastinoyu ciyeyi fazi ye perevirka vidpovidnosti tipiv danih Same protyagom semantichnogo analizu viyavlyayut pomilki privedennya tipiv vikoristannya neinicijovanih zminnih vidkladenogo viznachennya tipiv U hodi analizu buduyetsya tablicya simvoliv klyuchove dzherelo posilan dlya podalshogo komponuvannya programi Generator promizhnogo kodu Redaguvati Protyagom svoyeyi roboti kompilyator mozhe mati odne abo navit dekilka promizhnih predstavlen kodu yak vhidni parametri dlya riznih faz kompilyaciyi Tak sintaksichne derevo pobudovane protyagom sintaksichnogo analizu ye prikladom takoyi promizhnoyi strukturi Prote tipovim principom pobudovi kompilyatoriv ye generaciya promizhnogo kodu u kinci fazi analizu dlya podalshoyi optimizaciyi ta translyaciyi u vihidnu movu Cej promizhnij kod she ne ye vihidnim kodom ale maye vazhlivi vlastivosti vin maye dosit legko generuvatisya ta legko translyuvatisya u cilovu movu Sintez back end Redaguvati Na bazi promizhnogo predstavlennya ta napovnenoyi tablici funkciyi konstruyuyetsya vihidna programa Oskilki pochatkovij vhidnij kod a vidpovidno i promizhne predstavlennya mozhe buti optimizovanij yak na bazi visokorivnevih pokrashen tak i beruchi do uvagi detalne znannya konkretnoyi arhitekturi vihodnogo kodu vin pidlyagaye dekilkom fazam analizu Analizuyetsya chas zhittya danih ta yih promizhne peremishennya za chas roboti programi deyaki bloki kodu identifikuyutsya yak mozhlivi kandidati do pidstanovki nizkorivnevim kodom Pislya analizu vidbuvayetsya optimizaciya ta rezultat pokrashen translyuyetsya u vihidnu movu Na cij fazi kompilyaciyi deyaki fazi vzhe ye neobov yazkovimi analiz optimizaciya i mozhut buti propusheni Poperednij analiz promizhnogo kodu Redaguvati Z chasiv pervinnih kompilyatoriv koli promizhnij kod bezposeredno translyuvavsya u vihidnu movu bulo rozrobleno veliku kilkist pokrashen utochnen ta optimizacij v zalezhnosti vid zmistu vhidnoyi programi Suchasni kompilyatori mozhut vikonuvati velikij nabir doslidzhen vhidnogo kodu shob dosyagti perevagi u produktivnosti vikoristovuvanij pam yati rozmiri vihidnogo fajla tosho Priklad rozpovsyudzhenih vidiv analizu Analiz potoku danih angl data flow analysis pobudova lancyuga vikoristannya viznachennya angl Use define chain na bazi yakogo u podalshogo vikonuyutsya chislenni optimizaciyi Analiz zalezhnostej poshuk instrukcij ta blokiv kodu yaki ne zalezhat vid poslidovnosti vikonannya v pevnomu konteksti Poshuk psevdonimiv angl alias v zalezhnosti vid togo chi vkazuyut pevni zminni u pevnij moment chasu na odin i toj samij ob yekt u pam yati ye psevdonimami mozhna robiti pripushennya shodo vzayemnoyi yih pidstanovki ta optimizaciyi Analiz oblasti vidimosti angl escape analysis dinamichnij analiz chasu zhittya ta oblasti vidimosti vkazivnikiv dlya efektivnishogo vikoristannya pam yati Na comu etapi takozh buduyetsya graf viklikiv struktura poslidovnosti viklikiv funkcij u vhidnomu kodi ta graf potoku keruvannya Optimizaciya promizhnogo kodu Redaguvati Optimizaciya ye promizhnim etapom pered kincevoyu pobudovoyu vihidnogo kodu pid chas yakogo kod mozhe buti pokrashenij zadlya shvidkodiyi rozmiru rezultuyuchogo fajlu efektivnih obchislen na paralelnih potokah vikonannya ob yemu vikoristovuvanij pam yati tosho Za masshtabom diyi optimizaciyu mozhna podiliti na lokalnu ta globalnu 5 Lokalna optimizaciya vidbuvayetsya u mezhah bazovogo bloku grupi poslidovnih komand bez rozgaludzhen i perehodiv i polyagaye u lokalnih polipshennyah 5 vidalennya kodu yakij ne vikoristovuyetsya poshuk totozhnih pidviraziv znizhennya skladnosti pidrahunkiv shlyahom zamini na bilsh deshevi operaciyi yak priklad stepin zaminiti mnozhennyam zgorannya konstant angl constant folding pidrahunok i zamina konstant yih znachennyami polipshennya povernennya znachennya lokalne rozpodilennya registriv angl register allocation Bilsh prosunutoyu ta rozshirenoyu ye globalna optimizaciya na rivni sutnostej sucilnoyi programi Pid chas globalnih optimizacij intensivno vikoristovuyutsya rezultati poperednih analiziv potoku danih zalezhnostej ta inshih Sered chislennih optimizacij mozhna vidiliti Globalne rozpodilennya registriv angl global register allocation Rozmotuvannya cikliv Usunennya zagalnih pidviraziv Avtomatichne rozparalelennya Optimizaciya cikliv dlya rozparalelennyaGeneraciya cilovogo kodu programi Redaguvati Ostannoyu fazoyu kompilyaciyi ye same stvorennya vihidnogo kodu programi Za stvorennya vidpovidaye generator cilovogo kodu yakij na bazi promizhnogo predstavlennya ta z urahuvannyam optimizacij vivodit ekvivalentnu vihidnu programu Osnovnimi vimogami do generatora ye zberezhennya semantichnogo zmistu vhidnogo kodu ta efektivne vikoristannya resursiv u vihidnomu kodi cili Vidilyayut taki zadachi pritamanni fazi generaciyi Vibir komand same translyaciya komand vhodu u kod cili Vporyadkuvannya komand viznachennya poryadku sliduvannya komand misce dlya ostannih mozhlivih optimizacij Rozpodil ta priznachennya registriv vibir zminnih yaki budut znahoditisya u pam yati v u kozhen moment chasu programi ta yih rozmishennya u konkretnih registrah Nalagodzhuvalna informaciya angl debug data dodayetsya same na cij finalnij stadiyi Vidi kompilyatoriv RedaguvatiZa principom roboti mozhna vidiliti taki vidi kompilyatoriv 6 Odnoprohidni kompilyaciya zdijsnyuyetsya v odin prohid propuskayuchi bagato promizhnih krokiv optimizacij i perevirok Pershi kompilyatori movi Pascal 7 Kompilyatori u zshitij kod angl threaded code kod yakij povnistyu skladayetsya z pidprogram Po suti kompilyator prosto zaminyuye kozhnu instrukciyu vhidnogo kodu na pidprogramu vihidnogo zshivaye z zagotivok 8 Takij kompilyator maye mova programuvannya Forth 9 Inkrementalni kompilyatori deyaki funkciyi mozhut buti skompilovani pid chas vikonannya inkrementalno napriklad u poyednanni z interpretovanim vikonannyam Takij tip kompilyatoriv poshirenij u simejstvi LISP Peredfinalnij kompilyator angl stage compiler yakij kompilyuye u vihidnu movu teoretichnoyi mashini Takij kompilyator realizovanij dlya movi programuvannya Prolog vin generuye vihidnij kod dlya abstraktnoyi mashini Uorrena angl Warren Abstract Machine 10 Dinamichnij kompilyator angl JIT just in time kompilyaciya na lotu Div nizhche Kompilyator zi zminnimi cilyami angl retargetable yakij vidnosno prosto mozhna zminiti dlya generaciyi cilovogo kodu pid inshu arhitekturu procesoru Zagalom taka vlastivist dosyagayetsya shlyahom znizhennya yakosti vihidnogo kodu u porivnyanni z cilovimi kompilyatorami pid konkretnij procesor Predstavnikom takogo tipu kompilyatoriv ye nabir GCC Kompilyator rozparalelennya yakij generuye vihidnih kod dlya zapusku na paralelnij arhitekturi Kompilyator kompilyatoriv en translyator sho sprijmaye formalnij opis movi programuvannya j generuye kompilyator dlya ciyeyi movi dzherelo Vektorizuvalnij Translyuye vihidnij kod v mashinnij kod komp yuteriv osnashenih vektornim procesorom Bagatoprohidnij kompilyator en Vidi kompilyatoriv C Borland InternationalVihid kompilyatora Turbo C yavlyaye soboyu rozumnij ale ne duzhe optimizovanij kod Krim zgortki konstant vidalennya zajvih zavantazhen registriv i algebrayichnih sproshen kompilyator vikonuye tilki znizhennya potuzhnosti vidalennya nedosyazhnogo kodu i rozmishennya zminnih u registrah Vin ne pidtrimuye inshi zagalni metodi optimizaciyi taki yak vidalennya zajvih zberezhen zagalnih pidviraziv i zminni indukciyi ciklu a takozh vinesennya invariantnogo kodu Turbo C rozumno keruye prologom i epilogom funkcij i vikoristannyam registriv zasilayuchi v stek i vityagayuchi tilki ti registri sho yavno vikoristovuyutsya useredini tila funkciyi Computer Innovation IncKompilyator C86Plus viroblyaye chudovij kod iz serednim rivnem optimizaciyi Vin vikonuye bazovi prijomi optimizaciyi taki yak zgortka konstant i rozmnozhennya kopij Odnak vin ne vikonuye rozmnozhennya konstant dlya vidalennya zajvih zberezhen Hocha kompilyator uspishno vikonuye algebrayichni sproshennya vin porodzhuye zajvi instrukciyi cherez te sho rozmishaye rezultati v registrah zamist togo shob pomishati yih u zminni Cej efekt viyavlyayetsya v tom sho pri rozmishenni zminnih u registrah pochinayutsya sprobi pererozmishennya tomu sho pri vikonanni dekilkoh operatoriv rezultati v dijsnosti povinni buti privlasneni vidpovidnim zminnim Hocha C86Plus uspishno spravlyayetsya zi zgortkoyu yavnih prisvoyuvan sho dublyuyutsya v odne prisvoyuvannya vidalennya zajvih zberezhen vin vikonuye hitlivo Vin ne vikonuye istotnu optimizaciyu cikliv Datalight IncZ poyavoyu Optimum C Datalight stala odnim z pershih postachalnikiv sho zaproponuvali optimizovanij kompilyator Hocha nabir testiv ne pidtverdiv naochno pretenziyi Datalight na globalnu optimizaciyu Optimum C spracyuvav tak dobre v deyakih fragmentah testu sho prodemonstruvav slabki fragmenti naboru yaki vimagayut zmin dlya udoskonalennya bazhanoyi perevirki Napriklad u pershij versiyi funkciyi jump compression ne povertalosya znachennya sho robilo vsi obchislennya i prisvoyuvannya u funkciyi zajvimi Optimum C viyaviv ce i vidaliv veliku chastinu kodu funkciyi vklyuchayuchi lancyuzhok perehodiv U testi rozmnozhennya konstant i kopij Optimum C viznachiv sho prisvoyuvannya i5 v oboh umovnih operatorah ye zajvim stosovno nastupnih prisvoyuvan Kompilyator vidaliv ne tilki ci prisvoyuvannya ale j umovni operatori Nezadovilnim viyavilosya vidalennya zajvih zberezhen znachen registriv Optimum C yedinij kompilyator sho namagavsya vikonati gliboke vidalennya zagalnih virazhen Perevirka zgenerovanogo kodu pokazala sho zagalne virazhennya i5 i2 bulo peremisheno vishe pershogo bazovogo bloku umovnogo operatora ale ne bulo vilucheno z drugogo Poza obmezhennyami na standartne vikoristannya registriv sho nakladayutsya simejstvom mikroprocesoriv 80x86 Optimum C rozumno vikoristovuye registri U funkciyi jump compression kozhen peredanij parametr buv pomishenij u registr Useredini tila funkciyi ne bulo posilan u pam yat krim pochatkovogo zasilannya v registri Odniyeyu vazhlivoyu oblastyu u yakij kompilyator Optimum C vimagaye polipshen ye optimizaciya cikliv Kompilyator ne namagayetsya vikonuvati vinesennya invariantnogo kodu i vidalennya zminnih indukciyi ciklu Test vikonannya pokazav sho kompilyator Datalight duzhe efektivno keruye vvedennyam visnovkom getc putc a inshi testi vikonuyutsya v prijnyatnij chas Lattice IncKompilyator sho maye veliku istoriyu Lattice MS DOS C poslidovno udoskonalyuvavsya z kozhnoyu novoyu versiyeyu Vin vidomij yak generator stabilnogo peredbachuvanogo kodu i vikonuye pomirnu optimizaciyu Lattice S vikonuye znizhennya potuzhnosti stisk lancyuzhka perehodiv i vidalennya zagalnih pidviraziv Vin ne vidalyaye prisvoyuvannya sho dublyuyutsya pislya testu vbudovanih funkcij i zajvi prisvoyuvannya u funkciyi dead code Lattice C ne vikonuye optimizaciyu cikliv Manx Software Systems IncKompilyator Aztec C86 zgeneruvav chudovij kod z dosit garnim rivnem optimizaciyi Krim zgortki konstant i algebrayichnih sproshen Aztec C86 vikonav znizhennya potuzhnosti i vidalennya zagalnih pidviraziv Odnak vin ne vikonav vidalennya zajvih prisvoyuvan i ne vidalyav nedosyazhnij kod Aztec C86 zgeneruvav kod dlya nedosyazhnogo operatora printf razom z bezumovnim perehodom cherez nogo Oskilki bud yaka programa na Si maye znachnu kilkist viklikiv funkcij zagolovok kozhnogo vikliku neobhidno minimizuvati Aztec C86 vikoristovuye nezvichajnij ale efektivnij pidhid do rishennya ciyeyi problemi Na vihodi kompilyatora vihodit tekst u movi asemblera sho obroblyayetsya okremim asemblerom Kompilyator vstavlyaye v tekst direktivi umovnogo asemblyuvannya navkolo kodu sho vstanovlyuye stekovij kadr i zberigaye registri Pislya generaciyi kodu funkciyi kompilyator viznachaye simvoli dlya keruvannya ustanovkoyu stekovogo kadru i zberezhennya tilki tih registriv sho vikoristovuyutsya u funkciyi Aztec C86 ne zmig virishiti zadachu peretvorennya lancyuzhka perehodiv v odin perehid do kincevoyi meti Vin takozh ne vikonuvav optimizaciyu cikliv Metaware IncHigh C viroblyaye chudovij kod iz serednim rivnem optimizaciyi Kompilyator vikonuye vsi bazovi vidi optimizaciyi vklyuchayuchi zgortku konstant i algebrayichni sproshennya vidalennya zajvih operacij zavantazhennya registriv znizhennya potuzhnosti i vidalennya zagalnih pidviraziv Kompilyator Metaware vidalyaye nedosyazhnij kod ale ne vidalyaye zajvi prisvoyuvannya High C rozumno vikoristovuye mashinno zalezhni instrukciyi Kompilyator udoskonalit zavantazhennya konstant iz krapkoyu sho plavaye vikoristovuyuchi komandu kopiyuvannya ryadkiv MOVS procesoriv 80x86 dlya zapisu znachen iz krapkoyu sho plavaye obchislenih pid chas kompilyaciyi Vin takozh generuye instrukciyu LEAVE procesoriv 80x86 dlya epilogu funkcij ale vstanovlyuye adresaciyu stekovogo kadru v prolozi funkciyi za dopomogoyu okremih instrukcij a ne vikoristovuyuchi bilsh trivalu instrukciyu ENTER Kompilyator High C ne vikonuye vinesennya invariantnogo kodu vazhlivij metod optimizaciyi cikliv Vin takozh ne zmig zastosuvati uspishne vidalennya zminnih indukciyi cikliv Vbudovani funkciyi pidtrimuyutsya dlya dekilkoh cilochislennih i strokovih operacij takih yak strlen Microsoft CU versiyi 5 0 svogo kompilyatora Si korporaciya Microsoft vivela na rinok PC visokij riven optimizaciyi kodu Microsoft pridilyaye bagato uvagi analizu cikliv C 5 0 yedinij z rozglyanutih kompilyatoriv sho vikonuye vinesennya invariantnogo kodu i sogodenne vidalennya zminnih indukciyi cikliv Kompilyator Microsoft C 5 0 chudovo vikoristovuye registri namagayuchis minimizuvati zvertannya do pam yati v tili ciklu Prostij priklad ciklu v kodi testu demonstruye stupin optimizaciyi cikliv yakij vikonuye Microsoft C 5 0 Kompilyator zastosovuye znizhennya potuzhnosti i cilkom vidalyaye konstantne mnozhennya viyavlyaye kincevij stan zminnih i pomishaye v registri vsi zminni vseredini ciklu C 5 0 vidalyaye cikl for i generuye kod tilki z metoyu ustanovki kincevogo stanu zminnoyi indeksu ciklu j operatora vklyuchenogo v cikl Kompilyator takozh dobre vikoristovuye registri Uvaga firmi Microsoft do optimizaciyi vinagorodzhuyetsya pri roboti testu vikonannya Vin vikonuyetsya za chas sho ye krashim chi blizko do krashogo po kozhnij kategoriyi WATCOMNovitnij supernik sho zavojovuye poziciyi na rinku kompilyatoriv C WATCOM C 6 0 div Product Watch Philip N Hisley za cej misyac C 6 0 viroblyaye kompaktnij kod sho chudovo vikoristovuye trohi obmezhenij komplekt registriv simejstva 80x86 Krim vikonannya bazovih prijomiv optimizaciyi vin pidtrimuye znizhennya potuzhnosti i vidalennya nedosyazhnogo kodu i zagalnih pidviraziv U toj chas yak Microsoft dosyagaye polipshennya kodu zavdyaki optimizaciyi cikliv WATCOM zbilshuye shvidkist shlyahom zmenshennya keruyuchih zagolovkiv viklikiv funkcij do yihnogo absolyutno minimalnogo rozmiru Vin dosyagaye cogo shlyahom perevazhnoyi peredachi parametriv cherez registri a ne cherez stek WATCOM duzhe dobre vidalyaye nedosyazhnij kod C 6 0 ne tilki vidaliv nepotribni prisvoyuvannya i nedosyazhnij kod useredini funkciyi ale vin takozh vidaliv prolog i epilog funkciyi i zgornuv usyu funkciyu do prostogo povernennya pripisavshi im ya funkciyi do instrukciyi povernennya osnovnoyi funkciyi Na zavershennya vsogo kompilyator vidaliv lokalnij viklik funkciyi Naskilki C 6 0 vitonchenij u znishenni marnoyi funkciyi nastilki zh vin bezpomichnij pri vidalenni marnogo prisvoyuvannya sho dublyuyetsya Najbilsh vazhliva oblast za yaku WATCOM C 6 0 yak i Optimum C ne zmig uzyatisya bula optimizaciya cikliv Vin ne pidtrimuye vinesennya invariantnogo kodu i vidalennya zminnoyi indukciyi cikliv Hocha C 6 0 ne vikonuye rozgortannya cikliv v okremi komandi vin takozh yak Datalight Optimum C i Computer Innovations C86Plus vikoristovuye komandu REP STOSW procesoriv 80x86 dlya inicializaciyi testovogo masivu zavdyaki chomu vidalyaye cikl Prekrasna generaciya kodu v WATCOM zokrema rozumne vikoristannya registriv daye jomu duzhe vazhlivu perevagu Vin peremig u bilshosti testiv sho intensivno vikoristovuyut procesor i pri comu vikonuvavsya dlya velikoyi modeli v krashij chas nizh bilshist inshih kompilyatoriv dlya maloyi modeli Do slabkih storin WATCOM mozhna vidnesti vvedennya vivedennya fajliv vikoristannya getc i putc Tut vin blizkij do najgirshih kompilyatoriv Strategiyi kompilyaciyi RedaguvatiKompilyatori sluguyut svoyim cilyam u riznij sposib dlya riznih mov programuvannya ta paradigm Tak yaksho istorichno pervinni kompilyatori translyuvali kod movi u aparatno zalezhnij asembler to z chasom vinikla potreba u dodatkovih metodah ta sharah abstrakciyi kompilyaciyi na lotu translyuvannya bilsh visokorivnevogo kodu v menshij za rivnem optimizaciyi po vikoristannyu vzhe skompilovanogo kodu tosho Poshireni strategiyi kompilyaciyi Kompilyaciya pered vikonannyam angl AOT ahead of time Klasichnij princip koli kompilyaciya provoditsya okremo vid vikonannya zazvichaj u vidminnomu vid miscya vikonannya seredovishi Kompilyatori mov programuvannya Pascal C C BASIC Fortran COBOL vikoristovuyut strategiyu takoyi poperednoyi kompilyaciyi PerevagiShvidke zavantazhennya v brauzeri Vitrachayetsya menshe chasu za rahunok togo sho zastosunok kompilyuyetsya do zavantazhennya v brauzer ta kincevi fajli mayut menshij rozmir Viyavlennya pomilok pid chas zbirki Mayetsya mozhlivist vipraviti vsi pomilki do zapusku zastosunku v rezhimi ekspluataciyi Pidvishena bezpeka Kompilyaciya pid chas vikonannya angl JIT just in time vidoma takozh yak dinamichna kompilyaciya Sut polyagaye u kompilyaciyi chasu vikonannya angl run time koli tekst vhidnoyi movi peretvoryuyetsya u mashinnij kod na lotu j tut zhe vikonuyetsya Cya tehnika poyednuye u sobi metodi yak poperednoyi kompilyaciyi u promizhnij kod tak i interpretaciyi cogo promizhnogo kodu pid chas vikonannya Buduchi bilsh prodvinutoyu tehnikoyu kompilyaciya na lotu maye dosit suvori vimogi do prostoti kompilyaciyi i ne ye docilnoyu dlya pevnih mov programuvannya 11 Principovim predstavnikom JIT kompilyaciyi ye seredovishe vikonannya movi Java pionerom zhe vvazhayetsya Smalltalk Transkompilyaciya abo kompilyaciya z odniyeyi visokorivnevoyi movi v inshu angl source to source Principovoyu vidminnistyu danoyi strategiyi ye te sho yak vhidnij tak i vihidnij kod ye movami programuvannya visokogo rivnya Tipovimi prikladami vikoristannya ye pidgotovka kodu dlya paralelnoyi optimizaciyi perekompilyaciya starishogo kodu dlya novoyi versiyi standartu movi programuvannya kompilyaciya mov nadbudov u bazovu movu Predstavnikami takih mov programuvannya ye CoffeeScript 12 Dart Haxe Coccinelle 13 Perekompilyaciya dinamichna kompilyaciya chastin programi pid chas vikonannya angl dynamic recompilation Osoblivist deyakih sered vikonannya emulyatoriv ta virtualnih mashin perekompilovuvati deyaku chastinu programi pid chas yiyi roboti Cya tehnika vikoristovuyetsya dlya perenosu kodu na inshu arhitekturu pid chas jogo vikonannya zokrema dlya zapusku zastarilih program na suchasnih operacijnih sistemah Shiroko vikoristovuyetsya Java run time 14 ta Net Common Language Runtime 15 a takozh bagatma virtualnimi mashinami Osnovnimi zavdannyami yaki povinen vikonuvati dinamichnij rekompilyator ye Chitannya mashinnogo kodu z vihidnoyi platformi Vidaye mashinnij kod dlya cilovoyi platformiVidomi kompilyatori RedaguvatiAmsterdam Compiler Kit nabir zasobiv dlya napisannya kompilyatoriv dlya sistemi Minix avtorstva Endryu Tanenbauma ta Serila Yakobsa GCC vidomij nabir kompilyatoriv C ta piznishe C stvorenij Richardom Stolmenom shiroko poshirenij u sviti Linux Clang kompilyator simejstva C C yakij vikoristovuye tehnologiyu LLVM virtualnoyi mashini na bazi promizhnogo predstavlennya kodu Turbo Pascal vidatnij kompilyator stvorenij Andersom Gejlsbergom u 1983 roci Turbo C kompilyator movi C rozroblenij kompaniyeyu Borland u 1987 roci Mono bagatoplatformovij nabir zasobiv ta kompilyator movi C u vilnomu dostupi PyPy JIT kompilyator movi Python napisanij na movi Python Generatori analizatoriv Redaguvati Pobudovani algoritmi sho peretvoryuyut opis vhidnoyi movi u programu sho vikonuye analiz i ye velika kilkist realizacij cih algoritmiv Ye takozh utiliti sho avtomatizuyut reshtu faz kompilyaciyi ta sistemi stvorennya kompilyatoriv u cilomuV Unix poshireni generator leksichnih analizatoriv F Lex ta generatori sintaksichnih analizatoriv Bison ta Yacc Literatura RedaguvatiCompilers Principles Techniques and Tools Arhivovano 24 Travnya 2016 u Wayback Machine English vid 2nd edition Addison Wesley 2006 09 10 ISBN 9780321486813 Engineering a Compiler Second Edition English vid 2 edition Morgan Kaufmann 2011 02 21 ISBN 9780120884780 Advanced Compiler Design and Implementation English vid 1 edition Morgan Kaufmann 1997 08 15 ISBN 9781558603202 Compiler Design in C English Prentice Hall 1990 01 01 ISBN 9780131550452 Modern Compiler Implementation in Java Arhivovano 25 Kvitnya 2016 u Wayback Machine English vid 2nd edition Cambridge University Press 2002 10 21 ISBN 9780521820608 Understanding and Writing Compilers A do it yourself guide English vid 3rd ed edition Palgrave 1979 10 01 ISBN 9780333217320 Let s Build a Compiler Arhivovano 8 Lyutogo 2016 u Wayback Machine compilers iecc com Procitovano 2016 03 27 Posilannya Redaguvati Hopper Grace The Education of a Computer Proceedings of the Association for Computing Machinery Conference 1952 reprinted Vol 9 No 3 4 1952 pp 271 281 a b v Glushkov V M Yushenko K L K L 1962 Vychislitelnaya mashina Kiev matematicheskoe opisanie ros Kiev Tehn lit a b v g Yushenko E L 1963 Adresnoe programmirovanie Kiyiv Derzhavne vidavnictvo tehnichnoyi literaturi s 288 Principles of Compiler Design English vid 2nd edition Addison Wesley 1 serpnya 1977 ISBN 9780201000221 a b Vilyams kniga Kompilyatory principy tehnologii i instrumentarij Kniga Drakona 2 2 izdanie www williamspublishing com s 705 706 Arhiv originalu za 4 Bereznya 2016 Procitovano 30 bereznya 2016 compilers net gt paedia gt compiler www compilers net Arhiv originalu za 19 Lipnya 2019 Procitovano 30 bereznya 2016 Turbo Pascal 3 0 Compiler and Code Generation Internals www pcengines ch Arhiv originalu za 13 Bereznya 2016 Procitovano 30 bereznya 2016 Threaded Code www complang tuwien ac at Arhiv originalu za 16 Bereznya 2016 Procitovano 30 bereznya 2016 Horn Joe What Exactly Is RPL Arhiv originalu za 17 Veresnya 2017 Warren s Abstract Machine A Tutorial Reconstruction wambook sourceforge net Arhiv originalu za 19 Sichnya 2022 Procitovano 2 kvitnya 2016 Aycock John 1 chervnya 2003 A Brief History of Just in time ACM Comput Surv 35 2 s 97 113 ISSN 0360 0300 doi 10 1145 857076 857077 Procitovano 27 bereznya 2016 List of languages that compile to JS jashkenas coffeescript GitHub Arhiv originalu za 31 Sichnya 2020 Procitovano 27 bereznya 2016 Semantic patching with Coccinelle LWN net lwn net Arhiv originalu za 15 Bereznya 2016 Procitovano 27 bereznya 2016 Java theory and practice Dynamic compilation and performance measurement www ibm com angl 21 grudnya 2004 Arhiv originalu za 17 Bereznya 2016 Procitovano 27 bereznya 2016 Understanding ASP NET Dynamic Compilation msdn microsoft com Arhiv originalu za 16 Bereznya 2016 Procitovano 27 bereznya 2016 Otrimano z https uk wikipedia org w index php title Kompilyator amp oldid 38688695