Cantitate/Preț
Produs

Modern Compiler Implementation in ML

Autor Andrew W. Appel
en Limba Engleză Paperback – 7 iul 2004

Implementarea unui compilator complet reprezintă unul dintre cele mai complexe proiecte de inginerie software, implicând gestionarea unor procese ce pornesc de la analiza lexicală și ajung până la generarea de cod mașină optimizat. În Modern Compiler Implementation in ML, considerăm că abordarea autorului Andrew W. Appel este esențială pentru dezvoltatorii care doresc să stăpânească nu doar teoria, ci și construcția efectivă a acestor sisteme. Volumul ghidează cititorul prin fazele critice de selecție a instrucțiunilor prin tree matching, analiza fluxului de date și alocarea registrelor prin metoda colorării grafurilor.

Subliniem structura progresivă a lucrării: prima parte, „Fundamentals of Compilation”, este calibrată pentru un curs introductiv, în timp ce secțiunea „Advanced Topics” explorează zone complexe precum forma SSA (Static Single Assignment), programarea funcțională și tehnicile de garbage collection. Față de Modern Compiler Implementation in Java, unde accentul cade pe ecosistemul orientat pe obiecte, această variantă utilizează limbajul ML pentru a evidenția eleganța și rigoarea structurilor de date recursive. Complementar volumului Engineering a Compiler de Keith D. Cooper, care se axează pe tehnici de optimizare a codului și suport runtime, lucrarea de față pune un accent mai mare pe interfețele clare dintre module și pe implementarea concretă a limbajelor funcționale.

Această ediție extinsă se integrează în opera autorului ca o piesă centrală de inginerie, fiind mai aplicată decât lucrările sale teoretice precum Program Logics for Certified Compilers. Cu 117 exerciții și 34 de tabele, volumul transformă conceptele abstracte în specificații tehnice riguroase, fiind un instrument de lucru indispensabil în dezvoltarea de software de sistem.

Citește tot Restrânge

Preț: 50068 lei

Preț vechi: 62585 lei
-20%

Puncte Express: 751

Carte tipărită la comandă

Livrare economică 02-16 iulie


Specificații

ISBN-13: 9780521607643
ISBN-10: 0521607647
Pagini: 552
Ilustrații: 80 b/w illus. 34 tables 117 exercises
Dimensiuni: 190 x 245 x 29 mm
Greutate: 0.96 kg
Editura: Cambridge University Press
Colecția Cambridge University Press
Locul publicării:New York, United States

De ce să citești această carte

Recomandăm această carte inginerilor software și cercetătorilor care doresc să înțeleagă arhitectura internă a compilatoarelor moderne. Cititorul câștigă o expertiză practică în utilizarea limbajului ML pentru a construi sisteme de traducere eficiente, învățând să gestioneze optimizări complexe de memorie cache și alocare de registre. Este resursa ideală pentru cei care vor să treacă de la simpla utilizare a unui limbaj la proiectarea uneltelor care îl fac posibil.


Despre autor

Andrew W. Appel este profesor și director al Departamentului de Informatică de la Universitatea Princeton, ocupând această funcție din 1986. Este o figură proeminentă în comunitatea academică, fiind recunoscut pentru contribuțiile sale majore în verificarea software-ului, securitatea calculatoarelor și limbaje de programare. Este unul dintre creatorii proiectului Standard ML of New Jersey, experiență care stă la baza rigurozității tehnice din lucrările sale despre compilatoare. Fellow al ACM și fost redactor-șef al ACM Transactions on Programming Languages and Systems, Andrew W. Appel îmbină expertiza în logică matematică cu ingineria sistemelor software.


Descriere scurtă

This new, expanded textbook describes all phases of a modern compiler: lexical analysis, parsing, abstract syntax, semantic actions, intermediate representations, instruction selection via tree matching, dataflow analysis, graph-coloring register allocation, and runtime systems. It includes good coverage of current techniques in code generation and register allocation, as well as functional and object-oriented languages, that are missing from most books. In addition, more advanced chapters are now included so that it can be used as the basis for two-semester or graduate course. The most accepted and successful techniques are described in a concise way, rather than as an exhaustive catalog of every possible variant. Detailed descriptions of the interfaces between modules of a compiler are illustrated with actual C header files. The first part of the book, Fundamentals of Compilation, is suitable for a one-semester first course in compiler design. The second part, Advanced Topics, which includes the advanced chapters, covers the compilation of object-oriented and functional languages, garbage collection, loop optimizations, SSA form, loop scheduling, and optimization for cache-memory hierarchies.

Cuprins

Part I. Fundamentals of Compilation: 1. Introduction; 2. Lexical analysis; 3. Parsing; 4. Abstract syntax; 5. Semantic analysis; 6. Activation records; 7. Translation to intermediate code; 8. Basic blocks and traces; 9. Instruction selection; 10. Liveness analysis; 11. Register allocation; 12. Putting it all together; Part II. Advanced Topics: 13. Garbage collection; 14. Object-oriented languages; 15. Functional programming languages; 16. Polymorphic types; 17. Dataflow analysis; 18. Loop optimizations; 19. Static single-assignment form; 20. Pipelining and scheduling; 21. The memory hierarchy; Appendix.

Descriere

Describes all phases of a modern compiler, including techniques in code generation and register allocation for imperative, functional and object-oriented languages.