COMP3161/COMP9161 Concepts of Programming Languages

Hello, if you have any need, please feel free to consult us, this is my wechat: wx91due

COMP3161/COMP9161

Concepts of Programming Languages

Sample Exam

Session 2 2011

Question 1 [25 Marks]

Consider the following inductive definition of evaluation rules for a restricted form of boolean expres- sions.

Boolean expressions:

Evaluation rules:


A) [7 marks]

Give the derivation of the evaluation for the following expression:

•  and(not(false); and(true; not(true)))

B) [7 marks]

Are the rules unambiguous? If so, briefly explain why. If not, give an example expression for which the set of rules allow more than a single derivation.

C) [11 marks]

The rules listed above give a small step semantics. List the inference rules which specify an equiv- alent big step semantics.

Question 2 [25 Marks]

A) [10 marks]

In the lecture, we discussed the E-machine as an example of an abstract machine which handles value bindings explicitly by maintaining a value environment. One of the possible return values of the E-machine are function closures.

i)  What is a function closure?

ii)  Give an example of an expression whose evaluation in the E-machine requires the creation of a closure.

B) [15 marks]

We discussed two distinct methods to handle exceptions: the first method required that, when an exception is thrown, the evaluation unrolls the stack until the matching catch-expression is found. The second method made it possible to directly jump to the matching catch-expression.  Describe the second method:

i)  What are the components of the state of the abstract machine?

ii)  How does the state of the machine change when a catch-expression is evaluated?

iii)  How does the state of the machine change when a raise-expression is evaluated?

For (ii) and (iii), you do not have to give the exact transition rule — it is sufficient to describe how the state is affected.

Question 3 [25 Marks]

A) [6 marks]

For each of the following three pairs of type expressions determine whether the pair has a most general unifier? If so, please provide it.

i)  (a , b)  →  (b , a) and (int , c) → (c ,  c)

ii)  a → (a , a) and (b , b) → b

iii)  int → int and float → int

B) [9 marks]

Give the principal type of the following (polymorphic) MinHs expressions:

i)  Inr(Inl(True))

ii)  letfun  f   (x)  is  fst   (snd   (x));

iii)  letfun  g   (x)  is

case  x  of  Inl(a)  ->  a

Inr(b)  ->  b

end

end

C) [10 marks]

Consider the following MinHs types:

• 8a.8b.(a * b → c) → (a → b → c)

• 8a.8b.(a → b) → (b → a)

• 8a.8b.8c.(a → b) → (b → c) → (c → a)

• 8a.() → a

• 8a.a → ()

For which of these types exist terminating MinHs functions?

Question 4 [25 Marks]

A) [10 marks]

Progress and preservation are central concepts for strongly typed languages.

i)  Give the definition of progress and of preservation in the context of a strongly typed language.

ii)  The presence of partial functions can be problematic with respect to progress.  Describe how they can be handled in a strongly typed language such that both progress and preservation still hold.

B) [5 marks]

Give an example each for a type constructor which is covariant and a type constructor which is contravariant in at least one of its argument positions.

C) [10 marks]

Java’s array type is covariant. Why is this problematic?


发表评论

电子邮件地址不会被公开。 必填项已用*标注