Neuerscheinungen 2017Stand: 2020-02-01 |
Schnellsuche
ISBN/Stichwort/Autor
|
Herderstraße 10 10625 Berlin Tel.: 030 315 714 16 Fax 030 315 714 14 info@buchspektrum.de |
Igor Zhirkov
Low-Level Programming
C, Assembly, and Program Execution on Intel© 64 Architecture
1st ed. 2017. xxvi, 435 S. 43 SW-Abb., 4 Farbabb. 254 mm
Verlag/Jahr: SPRINGER, BERLIN; APRESS 2017
ISBN: 1-484-22402-7 (1484224027)
Neue ISBN: 978-1-484-22402-1 (9781484224021)
Preis und Lieferzeit: Bitte klicken
Learn Intel 64 assembly language and architecture, become proficient in C, and understand how the programs are compiled and executed down to machine instructions, enabling you to write robust, high-performance code.
Low-Level Programming explains Intel 64 architecture as the result of von Neumann architecture evolution. The book teaches the latest version of the C language (C11) and assembly language from scratch. It covers the entire path from source code to program execution, including generation of ELF object files, and static and dynamic linking. Code examples and exercises are included along with the best code practices. Optimization capabilities and limits of modern compilers are examined, enabling you to balance between program readability and performance. The use of various performance-gain techniques is demonstrated, such as SSE instructions and pre-fetching. Relevant Computer Science topics such as models of computation and formal grammars are addressed, and their practical value explained.
What You´ll Learn
Low-Level Programming teaches programmers to:
Freely write in assembly language
Understand the programming model of Intel 64
Write maintainable and robust code in C11
Follow the compilation process and decipher assembly listings
Debug errors in compiled assembly code
Use appropriate models of computation to greatly reduce program complexity
Write performance-critical code
Comprehend the impact of a weak memory model in multi-threaded applications
Who This Book Is For
Intermediate to advanced programmers and programming students
Part I: Assembly Language and Computer Architecture.-
Chapter 1: Basic Computer Architecture.-
Chapter 2: Assembly Language.-
Chapter 3: Legacy.-
Chapter 4: Virtual Memory.-
Chapter 5: Compilation Pipeline.-
Chapter 6: Interrupts and System Calls.-
Chapter 7: Models of Computation.-
Part II: The C Programming Language.-
Chapter 8: Basics.-
Chapter 9: Type System.-
Chapter 10: Code Structure.-
Chapter 11: Memory.-
Chapter 12: Syntax, Semantics, and Pragmatics.-
Chapter 13: Good Code Practices.-
Part III: Between C and Assembly.-
Chapter 14: Translation Details.-
Chapter 15: Shared Objects.-
Chapter 16: Performance.-
Chapter 17: Multithreading.-
Part IV: Appendices.-
Chapter 18: Appendix A: Using gdb.-
Chapter 19: Appendix B: Using Make.-
Chapter 20: Appendix C: System Calls.-
Chapter 21: Appendix D: Performance Tests.-
Chapter 22: Bibliography.-
Igor Zhirkov teaches his highly successful "System Programming Languages" course at ITMO University in Saint Petersburg. He studied at Saint Petersburg Academic University and received his master degree from ITMO University. Currently, he is doing research in verified C refactorings as part of his PhD thesis and formalization of Bulk Synchronous Parallelism library in C at IMT Atlantique in Nantes, France. His main interests are low-level programming, programming language theory, and type theory.