School of Engineering and Technology, (SET) | ||||
AT70.07 : Programming Languages and Compilers 3(3-0) | ||||
Course objectives: | ||||
To provide students with an in depth knowledge of concepts that underlie all of the programming languages normally encountered, illustrating those concepts with examples from various languages. Language design and implementation and the ways in which they interact are explored together. Special emphasis is put on compilation and linking, as well as how data types are implemented in memory. |
||||
Learning Outcomes: | ||||
Compilation, interpretation, regular expression and context-free grammars, scanners and parsers, names, scopes and bindings, scope rules, overloading, semantic analysis, code optimization techniques, control flow and expression evaluation, iteration and recursion, data types, type checking, parameter passing, exception handling, code generation, linking, encapsulation and inheritance, late binding, multiple inheritance. |
||||
Pre-requisite(s): | ||||
None |
||||
Course Outline: | ||||
|
||||
Learning Resources: | ||||
Textbook: | ||||
Lecture Notes |
||||
Reference Books: | ||||
D. A. Watt, D. F. Brown, D. Brown, D. Watt:
Programming Language Processors in Java: Compilers and Interpreters, Morgan Kaufmann Publishers, 2000.
R.W. Sebesta:
Concepts of Programming Languages, 4th Edition, Addison-Wesley, 1999.
A. W. Appel, J. Palsberg:
Modern compiler implementation in Java, 2nd Edition, Cambridge University Press, 2002.
B.J. MacLennan:
Principles of Programming Languages: Design, Evaluation, and Implementation, 3rd Edition, Oxford University Press, 1999.
N. Wirth:
Compiler Construction, Addison-Wesley, 1996.
B. C. Pierce:
Types and Programming Languages, The MIT Press, 2002.
A. Sampaio:
An Algebraic Approach To Compiler Design, World Scientific, 1997.
R. Wilhelm, D. Maurer:
Compiler Design Reading, Addison-Wesley, 1995.
A. V. Aho, R. Sethi, J. D. Ullman:
Compilers: Principles, Techniques, and Tools Reading, Addison-Wesley, 1986.
S.S. Muchnick:
Advanced Compiler Design and Implementation, Morgan Kaufmann Publishers, 1997.
T. Pittman, J. Peters, J. Peters:
The Art of Compiler Design: Theory and Practice, Prentice Hall, 1991.
|
||||
Evaluation Scheme: | ||||
The final grade will be computed from the following constituent parts:
Mid-semester exam - (20%)
Final exam - (50%)
Assignments/projects - (30%)
Open-book examination is used for both mid-semester and final exam.
|
||||
Instructor(s): | ||||
|
||||