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);

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
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.
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education