10.21 Consider the Java program shown in Figure 10.8. Assume that this is to be compiled to native code on a machine with 4-byte addresses. (a) Draw a picture of the layout in memory of the object created at line 15. Show all virtual function tables. (b) Give assembly-level pseudocode for the call to c.val at line 18. You may assume that the address of c is in register r1 immediately before the call, and that this same register should be used to pass the hidden this parameter. You may ignore the need to save and restore registers, and don't worry about where to put the return value. 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. interface Pingable { } public void ping(); class Counter implements Pingable { int count = 0; public void ping() { ++count; } } public int val() { return count; public class Ping { public static void main(String args[]) { Counter c= new Counter(); 13. 14. 15. 16. 17. 18. 19. 20. 21. } Figure 10.8 A simple program in Java. } c.ping(); c.ping(); int v= c.val(); System.out.println (v);

C++ Programming: From Problem Analysis to Program Design
8th Edition
ISBN:9781337102087
Author:D. S. Malik
Publisher:D. S. Malik
Chapter12: Points, Classes, Virtual Functions And Abstract Classes
Section: Chapter Questions
Problem 19SA
icon
Related questions
Topic Video
Question
Please help me with this Principles of programming language homework question
10.21 Consider the Java program shown in Figure 10.8. Assume that this is to be compiled to
native code on a machine with 4-byte addresses.
(a) Draw a picture of the layout in memory of the object created at line 15. Show all virtual
function tables.
register
(b) Give assembly-level pseudocode for the call to c.val at line 18. You may assume that the
address of c is in register r1 immediately before the call, and that this same should
be used to pass the hidden this parameter. You may ignore the need to save and restore
registers, and don't worry about where to put the return value.
1.
2.
3.
4.
5.
6.
Ó NOIN MISCH
9.
10.
11.
12.
interface Pingable {
14.
15.
public void ping();
}
class Counter implements Pingable {
int count = 0;
public void ping() {
++count;
}
}
public int val() {
return count;
}
13. public class Ping {
public static void main(String args[]) {
Counter c= new Counter();
16.
17.
18.
19.
20.
21. }
Figure 10.8 A simple program in Java.
c.ping();
c.ping();
int v= c.val();
System.out.println(v);
}
ID No.
Transcribed Image Text:10.21 Consider the Java program shown in Figure 10.8. Assume that this is to be compiled to native code on a machine with 4-byte addresses. (a) Draw a picture of the layout in memory of the object created at line 15. Show all virtual function tables. register (b) Give assembly-level pseudocode for the call to c.val at line 18. You may assume that the address of c is in register r1 immediately before the call, and that this same should be used to pass the hidden this parameter. You may ignore the need to save and restore registers, and don't worry about where to put the return value. 1. 2. 3. 4. 5. 6. Ó NOIN MISCH 9. 10. 11. 12. interface Pingable { 14. 15. public void ping(); } class Counter implements Pingable { int count = 0; public void ping() { ++count; } } public int val() { return count; } 13. public class Ping { public static void main(String args[]) { Counter c= new Counter(); 16. 17. 18. 19. 20. 21. } Figure 10.8 A simple program in Java. c.ping(); c.ping(); int v= c.val(); System.out.println(v); } ID No.
Expert Solution
steps

Step by step

Solved in 3 steps

Blurred answer
Knowledge Booster
Instruction Format
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
C++ Programming: From Problem Analysis to Program…
C++ Programming: From Problem Analysis to Program…
Computer Science
ISBN:
9781337102087
Author:
D. S. Malik
Publisher:
Cengage Learning
C++ for Engineers and Scientists
C++ for Engineers and Scientists
Computer Science
ISBN:
9781133187844
Author:
Bronson, Gary J.
Publisher:
Course Technology Ptr