精華區beta NTU-Exam 關於我們 聯絡資訊
課程名稱︰程式語言 課程性質︰資管系選修 課程教師︰莊庭瑞 開課學院:管理學院 開課系所︰資管系 考試日期(年月日)︰2009.6.17 考試時限(分鐘):120分鐘 是否需發放獎勵金:是 (如未明確表示,則不予發放) 試題 : Part 1. Answer ○ if the statement is true; answer ╳ if the statement is false. 4 points for each question. 1 In Smalltalk, one can tell which object is bound to self by looking at the program text alone. 2 Both C++ and Smalltalk use garbage collection to manage memory. 3 Blocks are used in Smalltalk to implement conditional expressions. 4 In C++, a static data members of a class C is shared by all objects of the class C. 5 In Smalltalk, a instance variable of a class C is shared by all objects of the class C. 6 The first-class synchronous value event and the related operators in Concurrent ML can be thought as language features for supporting procedural abstraction. 7 Java suffers from the “ diamond inheritance problem” because a class may implement multiple interfaces. Given the following Prolog facts and rules edge(a, b). edge(b, c). edge(a, c). edge(b, d). edge(e, d). edge(e, f). connect(X, X). connect(X, Y) :- edge(X, Y). connect(X, Y) :- edge(X, Z), connect(Z, Y). Answer question 8, 9, and 10. 8 Query connect(e, e). returns no. 9 Query connect(a, f). returns no. 10 There are only three solutions to the query edge(X, Y), edge(X, Z), Y \= Z. (Note: Y \= Z is GNU Prolog for Y not unifiable with Z.) Part 2. Answer clearly, either in Chinese or English, solutions to the following questions. 1. In a language with first-class functions and static scope, a function value is generally represented by a closure, which is a pair consisting of a pointer to function code and a pointer to an activation record. The following ML code shows that, in a sense, one can simulate objects by using colsures. fun new (x) = let val c = ref x fun f x = c := !c + x fun g () = !c in (f, g) end (a) (5 points) Explain the above code, and write a few lines of ML code which when executed will create two objects. Use the two objects in some interesting ways, for example, for keeping the score of a basketball game. (b) (5 points) How can the above ML code be improved if in addition ML records are used in the simulation? Rewrite the above code using records, show how to create two objects, and how to use them in your example. (c) (5 points) Criticize this objects-by-closures simulation from the viewpoint of data abstraction (even if ML records are used). 2. The textbook uses the following C++ code to illustrate the singleton design pattern. Class Singleton { public: static Singleton* instance(); protected: Singleton(); private: static Singleton* _instance; }; Singleton* Singleton::_instance = 0; Singleton* Singleton::instance() { if (_instance == 0) { _instance = new Singleton(); } return _instance; } (a) (5 points) Explain what does the above C++ code do, and how do the class constructs in C++ help in this design. You must say what public, protected, private, and static are for, and how do they help in this design. (b) (5 points) How can the above class be rewritten to support a poll of fixed number of instances. That is, at most only k instances can be used at a time, where k is a constant. You need to consider what shall be done when a user wants to create an instance, and what to do when an instance is destroyed. You need not write the complete C++ code, but must describe precisely what the procedures are, and how the C++ class constructs are used in your design. 3. (10 points) It is said that "subtyping is a relation on interfaces; inheritance is a relation on implementations." Explain. 4. (10 points) What is subtype polymorphism, and what is parametric polymorphism? Of the two languages Java and ML? Which language has which polymorphism? Explain. 5. Given the following subtype relationships between classes Object, Shape, Circle, and Square (note: no other subtype relationships exist): Shape <: Object Circle <: Shape Square <: Shape and the following Java code: Object o = new Object(); Shape x = new Shape(); Circle y = new Circle(); Square z = new Square(); if (...) (* ... is some condition unknown at compile-time *) { x = y; } (*1*) else { x = z; } (*2*) o = x; (*3*) x = o; (*4*) y = o; (*5*) z = o; (*6*) (a) (5 points) Of the six lines from (*1*) to (*6*), which will cause compile-time type errors? Why? (b) (5 points) Some of lines that cause compile-time type errors actually will never cause problems at run-time? Which lines and Why? How do you use explicit type casts to avoid these spurious compile-time type errors. (c) (5 points) What does an explicit type cast do at run-time? That is, what is "run-time type conversion"? Even if explicit type casts are used at all lines in the above Java code to avoid all compile-time type errors, some lines may still cause problems at run-time. Which lines? Explain. -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 140.112.5.53