Đang chuẩn bị nút TẢI XUỐNG, xin hãy chờ
Tải xuống
Lecture Programming languages (2/e) - Chapter 2: Syntax. The main contents of this chapter include all of the following: Compilers and interpreters; linking syntax and semantics: abstract syntax, abstract syntax trees, abstract syntax of clite. | Programming Languages 2nd edition Tucker and Noonan Chapter 2 Syntax A language that is simple to parse for the compiler is also simple to parse for the human programmer. N. Wirth Contents 2.1 Grammars 2.1.1 Backus-Naur Form 2.1.2 Derivations 2.1.3 Parse Trees 2.1.4 Associativity and Precedence 2.1.5 Ambiguous Grammars 2.2 Extended BNF 2.3 Syntax of a Small Language: Clite 2.3.1 Lexical Syntax 2.3.2 Concrete Syntax 2.4 Compilers and Interpreters 2.5 Linking Syntax and Semantics 2.5.1 Abstract Syntax 2.5.2 Abstract Syntax Trees 2.5.3 Abstract Syntax of Clite 2.4 Compilers and Interpreters Lexical Analyzer Syntactic Analyzer Semantic Analyzer Code Optimizer Code Generator Tokens Abstract Syntax Machine Code Intermediate Code (IC) Source Program Intermediate Code (IC) Lexer Input: characters Output: tokens Separate: Speed: 75% of time for non-optimizing Simpler design Character sets End of line conventions Parser Based on BNF/EBNF grammar Input: tokens Output: abstract syntax tree (parse tree) Abstract syntax: parse tree with punctuation, many nonterminals discarded Semantic Analysis Check that all identifiers are declared Perform type checking Insert implied conversion operators (i.e., make them explicit) Code Optimization Evaluate constant expressions at compile-time Reorder code to improve cache performance Eliminate common subexpressions Eliminate unnecessary code Code Generation Output: machine code Instruction selection Register management Peephole optimization Interpreter Replaces last 2 phases of a compiler Input: Mixed: intermediate code Pure: stream of ASCII characters Mixed interpreters Java, Perl, Python, Haskell, Scheme Pure interpreters: most Basics, shell commands 2.5 Linking Syntax and Semantics Output: parse tree is inefficient Example: Fig. 2.9 Parse Tree for z = x + 2*y; Fig. 2.9 Finding a More Efficient Tree The shape of the parse tree reveals the meaning of the program. So we want a tree that removes its inefficiency and keeps its shape. Remove | Programming Languages 2nd edition Tucker and Noonan Chapter 2 Syntax A language that is simple to parse for the compiler is also simple to parse for the human programmer. N. Wirth Contents 2.1 Grammars 2.1.1 Backus-Naur Form 2.1.2 Derivations 2.1.3 Parse Trees 2.1.4 Associativity and Precedence 2.1.5 Ambiguous Grammars 2.2 Extended BNF 2.3 Syntax of a Small Language: Clite 2.3.1 Lexical Syntax 2.3.2 Concrete Syntax 2.4 Compilers and Interpreters 2.5 Linking Syntax and Semantics 2.5.1 Abstract Syntax 2.5.2 Abstract Syntax Trees 2.5.3 Abstract Syntax of Clite 2.4 Compilers and Interpreters Lexical Analyzer Syntactic Analyzer Semantic Analyzer Code Optimizer Code Generator Tokens Abstract Syntax Machine Code Intermediate Code (IC) Source Program Intermediate Code (IC) Lexer Input: characters Output: tokens Separate: Speed: 75% of time for non-optimizing Simpler design Character sets End of line conventions Parser Based on BNF/EBNF grammar Input: tokens Output: abstract syntax tree .