Lund University →
Faculty of Engineering →
Department of Computer Science
  Skills
  
    This page lists all technical skills of relevance to this class,
    as a study guide.  If you find that you possess all the skills
    listed here, you can consider yourself to have mastered the class.
    The final exam will draw its expectations from this list: each
    question in the exam can be solved by using
    and synthesising the skills listed here, basic arithmetic, and
    general computer science knowledge from the prerequisite undergraduate core
    classes.
  
  The percentage of synthesis tasks in which you have to
  combine known skills in ways not directly covered in the class will
  be no more than 25% of the total points in the final exam.
  
    Note that the list is preliminary and will be updated throughout the course.
  
  Concepts
  For each concept (maked in bold-face below) be able to do the following:
  
    - Give matching examples
- Distinguish it from other concepts
- Explain its relationship to any other concepts (is-part-of, is-alternative-to, is-generalisation-of etc.)
- Explain the purpose or utility of the concept
The book provides a convenient common framework for arguing about the benefits and disadvantages of language features and programming languages in general. Table 1.1 and, more generally, Section 1.3 in the book describe a number of axes along which we can try to understand the effect of language features and the qualities of programming languages.
-     You should be able to recognise and describe all the characteristics listed in Table 1.1, as well as the three basic criteria listed therein.
-     For some language feature, you should be able to recognise the characteristics and criteria affected by that feature's presence or absence.
-     For two related language features, you should be able to compare them, based on the three criteria from Table 1.1.
-     For some language feature, you should be able to recognise and explain how it can affect the Cost considerations for training, compile time, execution time, and cost of poor reliability as outlined in Section 1.3.7.
You should be familiar with the following concepts::
    
        - Language implementation via pure interpretation, compilation, and hybrid implementation
- Language implementation with the help of a just-in-time compiler
    Syntax describes the possible structure (or form) of programs of a given programming language. Backus-Naur Form (BNF) grammars have emerged as the standard mechanism for describing language syntax. BNF grammars used to describe languages when communicating with language adopters and compiler implementors. There are also many tools (particularly the yacc and antlr families of programs) for automatically generating parsers, programs that recognise whether an input program matches a grammar and, if it does, execute user-defined actions upon encountering certain language constructs.
    
      - You should be able to determine whether a given property of a language is part of the syntax, of the static semantics, or of the dynamic semantics.
- You should be able to read a BNF grammar and understand the difference between terminals and nonterminals.
- Given a BNF grammar, you should be able to write down examples of programs that can be generated by the grammar.
- Given a BNF grammar, you should be able to tell whether a given program can be generated by the grammar. If the program is generated by the grammar, you should also be able to generate a parse tree for the program.
- You should be able to determine whether a given (small) BNF grammar is ambiguous (the problem is undecidable in general, so this skill only pertains to practically relevant examples as covered in the textbook).
- Given a BNF grammar, you should be able to determine the associativity of any operator used therein.
- You should be able to describe the difference between an object language and a meta-language.
- Understand arity, fixity, and precedence, and associativity of operators
    There are many ways to describe semantics.  In this course, we focus on natural semantics (also known as Big-Step Operational Semantics).
    
    -  You should be able to read a specification of natural semantics.
- Given a natural semantics and a parse tree (or unambiguous expression), you should be able to compute the semantics of the given program.
- Given a natural semantics and a BNF grammar, you should be able to tell whether any parts of the semantics are undefined.
- Given an understanding of what a state-free expression language is supposed to do, you should be able to write down a simple natural semantics for it.
- You should be able to understand the concepts of Environments in the context of natural semantics and be able to utilise it when reading and reasoning about natural semantics.
  
    - You should understand the difference between static and dynamic type binding and be able to take advantage of either property in your programming.
- Given a syntax, a compiler and a run-time system for a language, you should be able to determine whether the language is using static or dynamic type binding.
- Concepts: static binding, stack-dynamic binding, explicit heap-dynamic binding, and implicit heap-dynamic binding.
- Given a syntax, a compiler and a run-time system for a language, you should be able to determine which storage binding(s) the language is using.
- Concept: lifetime of a variable
- Concepts: allocation and deallocation of a heap-dynamic variable
- Concept: binding time, especially the difference between static and dynamic binding times
  
    - You should understand the difference between static scoping and dynamic scoping and be able to exploit either in your programming.
- Given a language implementation, you should be able to write a program to determine whether the language uses static or dynamic scoping.
- Concept: referencing Environment
    
      - Concepts: the types of integers, floating-point numbers (floats), and decimal numbers (decimals)
- Concept: the type of booleans
- Concept: enumeration type
- Concepts: character and string types
- Concept: subrange types
- Concept: record types
- Concept: tuple types
- Concept: list types
- Concept: associative array types
- Concept: union types, both free and discriminated
- Concept: operator overloading
- Concepts: strong typing and weak typing
- Concepts: type checking and the differences between dynamic type checking, static type checking.
- Concepts: type equivalence, including the difference between nominal and structural type equivalence
- Concept: type constructors
- Concept: typing rules as part of type systems, and how to read such rules and utilise them in your reasoning about program semantics
- Concept: the type preservation property, also known as subject reduction, of type systems
- Concepts: type parameters and parametric polymorphism
- Concept: function types for subroutines
- Concept: type classes
- Concept: subtyping
- Concept: covariance and contravariance of type parameters, and the arrow rule
- Concept: bounded parametric polymorphism
- Concept: definition-site variance and use-site variance of type parameters
- Concept: Algebraic Datatypes as in Standard ML and their use in pattern-matching
- Concept: automatic Type Inference
  
    - Concept: arithmetic expressions
- Concepts: boolean expressions and relational expressions
    
- Concepts: Different forms of object equality, including reference equality and structural equality
- Concept: operand evaluation order and how it affects the outcome of programs
- Concept: short-circuit evaluation and how it affects the outcome of programs
- Concept: referential transparency and side effects
- Concept: list comprehensions and their semantics
- Concept: type coercion expressions, both explicit and implicit, including narrowing conversions and widening conversions
- Concept: conditional expressions
    
      - Concept: assignment statements, including compound assignment
- Concept: two-way selection statements
- Concept: multiple-selection statements
- Concept: counter-controlled loops
- Concept: logically controlled loops
- Concept: datastructure-controlled loops
    
      - Concepts: subprograms, including formal arguments and actual arguments
- Concept: local variables in subprograms
- Concept: nested subprograms
- Concepts: parameter passing modes
	
	  - by value
- by result
- by value-result
- by reference
- by name
- by need
 
- Concepts: subprograms as parameters, subprograms as return values, Closures
- Concept: activation records
    
      - Concepts: pointers and references
- Concept: the dangling pointer problem
- Concepts: garbage collection in the forms of reference counting and mark-and-sweep collection
- Concept: arrays in the forms of
	
	  - static arrays
- fixed stack-dynamic arrays
- fixed heap-dynamic arrays
- heap-dynamic arrays
 
    
      - Concepts: information hiding and encapsulation
- Concept: abstract datatypes
- Concept: generic abstract datatypes, that is, abstract datatypes that take one or more type parameters
    
      - Concept: object-oriented language
- Concept: dynamic dispatch, also known as dynamic binding of methods
- Concept: inheritance
- Concept: method overriding
- Concept: the combined use of static types and dynamic types in statically typed object-oriented languages
    
      - Concept: local let bindings of variables
- Concept: anonymous functions, also known as lambda expressions
- Concept: first-class functions
- Concepts: pattern matching, including wildcards
      
- Concepts: exhaustiveness and redundancy in pattern matching
- Concept: lists as algebraic datatypes
- Concept: the map function
- Concept: currying
- Functional Programming in Standard ML
    
      - Concepts: exceptions and exception handlers