My Account Log in

1 option

Programming Language Concepts / by Peter Sestoft.

SpringerLink Books Computer Science (2011-2024) Available online

View online
Format:
Book
Author/Creator:
Sestoft, Peter, author.
Contributor:
SpringerLink (Online service)
Series:
Computer Science (Springer-11645)
Undergraduate topics in computer science 1863-7310
Undergraduate Topics in Computer Science, 1863-7310
Language:
English
Subjects (All):
Programming languages (Electronic computers).
Data structures (Computer science).
Programming Languages, Compilers, Interpreters.
Data Storage Representation.
Local Subjects:
Programming Languages, Compilers, Interpreters.
Data Storage Representation.
Physical Description:
1 online resource (XV, 341 pages) : 87 illustrations.
Edition:
Second edition 2017.
Contained In:
Springer eBooks
Place of Publication:
Cham : Springer International Publishing : Imprint: Springer, 2017.
System Details:
text file PDF
Summary:
This book uses a functional programming language (F#) as a metalanguage to present all concepts and examples, and thus has an operational flavour, enabling practical experiments and exercises. It includes basic concepts such as abstract syntax, interpretation, stack machines, compilation, type checking, garbage collection, and real machine code. Also included are more advanced topics on polymorphic types, type inference using unification, co- and contravariant types, continuations, and backwards code generation with on-the-fly peephole optimization. This second edition includes two new chapters. One describes compilation and type checking of a full functional language, tying together the previous chapters. The other describes how to compile a C subset to real (x86) hardware, as a smooth extension of the previously presented compilers.The examples present several interpreters and compilers for toy languages, including compilers for a small but usable subset of C, abstract machines, a garbage collector, and ML-style polymorphic type inference. Each chapter has exercises. Programming Language Concepts covers practical construction of lexers and parsers, but not regular expressions, automata and grammars, which are well covered already. It discusses the design and technology of Java and C# to strengthen students' understanding of these widely used languages.
Contents:
Introduction
Interpreters and Compilers
From Concrete Syntax to Abstract Syntax
A First-Order Functional Language
Higher-Order Functions
Polymorphic Types
Imperative Languages
Compiling Micro-C
Real-World Abstract Machines
Garbage Collection
Continuations
A Locally Optimizing Compiler
Compiling Micro-SML
Real Machine Code
A Crash Course in F#.
Other Format:
Printed edition:
ISBN:
978-3-319-60789-4
9783319607894
Access Restriction:
Restricted for use by site license.

The Penn Libraries is committed to describing library materials using current, accurate, and responsible language. If you discover outdated or inaccurate language, please fill out this feedback form to report it and suggest alternative language.

My Account

Shelf Request an item Bookmarks Fines and fees Settings

Guides

Using the Library Catalog Using Articles+ Library Account