ACM Home Page
Please provide us with feedback. Feedback
GCspy: an adaptable heap visualisation framework
Full text PdfPdf (216 KB)
Source Conference on Object Oriented Programming Systems Languages and Applications archive
Proceedings of the 17th ACM SIGPLAN conference on Object-oriented programming, systems, languages, and applications table of contents
Seattle, Washington, USA
SESSION: Tools table of contents
Pages: 343 - 358  
Year of Publication: 2002
ISBN:1-58113-471-1
Also published in ...
Authors
Tony Printezis  University of Glasgow, Glasgow, Scotland
Richard Jones  University of Kent at Canterbury, Canterbury, U.K.
Sponsors
ACM: Association for Computing Machinery
SIGPLAN: ACM Special Interest Group on Programming Languages
Publisher
ACM  New York, NY, USA
Bibliometrics
Downloads (6 Weeks): 6,   Downloads (12 Months): 47,   Citation Count: 6
Additional Information:

abstract   references   cited by   index terms   collaborative colleagues  

Tools and Actions: Request Permissions Request Permissions    Review this Article  
DOI Bookmark: Use this link to bookmark this Article: http://doi.acm.org/10.1145/582419.582451
What is a DOI?

ABSTRACT

GCspy is an architectural framework for the collection, transmission, storage and replay of memory management behaviour. It makes new contributions to the understanding of the dynamic memory behaviour of programming languages (and especially object-oriented languages that make heavy demands on the performance of memory managers). GCspy's architecture allows easy incorporation into any memory management system: it is not limited to garbage-collected languages. It requires only small changes to the system in which it is incorporated but provides a simple to use yet powerful data-gathering API. GCspy scales to allow very large heaps to be visualised effectively and efficiently. It allows already-running, local or remote systems to be visualised and those systems to run at full speed outside the points at which data is gathered. GCspy's visualisation tool presents this information in a number of novel ways.Deep understanding of program behaviour is essential to the design of the next generation of garbage collectors and explicit allocators. Until now, no satisfactory tools have been available to assist the implementer in gaining an understanding of heap behaviour. GCspy has been demonstrated to be a practical solution to this dilemma. It has been used to analyse production Java virtual machines running applications of realistic sizes. Its use has revealed important insights into the interaction between application program and JVM and has led to the development of better garbage collectors.


REFERENCES

Note: OCR errors may be found in this Reference List extracted from the full text article. ACM has opted to expose the complete List rather than only correct and linked references.

 
1
2
 
3
4
 
5
 
6
Borland Inc. The OptimizeIt tool. http://www.optimizeit.comNovember 12, 2001.
 
7
L. Cardelli, J. Donahue, L. Glassman, M. J. Jordan, B. Kalsow, and G. Nelson. Modula-3 report. Technical Report 52, Systems Research Center, Digital Equipment Corporation, Palo Alto, CA, September 1989. Revised.
8
9
 
10
 
11
W. De Pauw and G. Sevitski. Visualizing Reference Patterns for Solving Memory Leaks in Java. Concurrency --- Practice and Experience, 12:1431--1454, 2000.
 
12
 
13
14
15
16
 
17
 
18
IBM Research. The Jinsight project. http://www.research.ibm.com/jinsight/November 12, 2001.
19
 
20
R. E. Jones. Garbage Collection: Algorithms for Automatic Dynamic Memory Management. John Wiley & Sons, Ltd, 1996. With a chapter on Distributed Garbage Collection by R. Lins.
 
21
R. E. Jones. Tail recursion without space leaks. Journal of Functional Programming, 2(1):73--79, January 1992.
 
22
G. N. C. Kirby and R. Morrison. OCB: An Object/Class Browser for Java. In Proceedings of the Second International Workshop on Persistence and Java (PJW2), pages 89--105, Half Moon Bay, CA, USA, August 1997.
 
23
D. Lea. The GNU C++ library. The C++ Report, 1993.
 
24
D. Lea. A memory allocator. The DLmalloc homepage http://gee.cs.oswego.edu/dl/html/malloc.html April 4, 2000, 1997.
 
25
 
26
S. L. Peyton Jones, C. V. Hall, K. Hammond, W. D. Partain, and P. L. Wadler. The Glasgow Haskell compiler: a technical overview. In Proceedings of Joint Framework for Information Technology Technical Conference, pages 249--257, Keele, March 1993.
27
28
 
29
C. Runciman and D. Wakeling. Heap profiling of lazy functional programs. Journal of Functional Programming, 3(2):217--245, April 1993.
 
30
K. Russell and L. Bak. The HotSpot Serviceability Agent: An Out-of-Process High-Level Debugger for a Java Virtual Machine. In Proceedings of the Usenix Java Virtual Machine Research and Technology Symposium (JVM'01), pages 117--126, Monterey, CA, USA, April 2001.
 
31
 
32
A. Shalit. The Dylan Reference Manual. Addison-Wesley, 1996.
 
33
Sitraka Inc. The JProbe Suite. http://www.jprobe.com/November 12, 2001.
 
34
R. M. Stallman. Debugging with GDB: The GNU Source-Level Debugger for GDB. Free Software Foundation, July 2000.
 
35
Standard Performance Evaluation Corporation. SPECjvm98 Documentation, release 1.03 edition, March 1999.
 
36
Sun Microsystems Inc. Java Debug Wire Protocol (JDWP). http://java.sun.com/j2se/1.3/docs/guide/jpda/jdwp-spec.htmlNovember 12, 2001.
 
37
Sun Microsystems Inc. Java Heap Analysis Tool (HAT). http://java.sun.com/people/billf/heap/November 12, 2001.
 
38
Sun Microsystems Inc. Java Platform Debugger Architecture (JPDA). http://java.sun.com/j2se/1.3/docs/guide/jpda/November 12, 2001.
 
39
Sun Microsystems Inc. Java Virtual Machine Profiling Interface (JVMPI). http://java.sun.com/j2se/1.3/docs/guide/jvmpi/November 12, 2001.
 
40
Sun Microsystems Inc. The Java HotSpot Virtual Machine, 2001. Technical White Paper.
41
42
43
 
44
 
45
M. Wallace, S. Novello, and J. Schimpf. ECLiPSe: A platform for constraint logic programming. Technical report, IC-Parc, Imperial College London, August 1997.
 
46
 
47
 
48
M. Wolczko. The Tracing JVM. http://research.sun.com/people/mario/tracing-jvm/ November 9, 2001.
 
49
M. Wolczko. Using a Tracing Java Virtual Machine to Gather Data on the Behaviour if Java Programs, March 1999. SML 98-0154.
 
50
M. Wolczko. Personal Communication, October 2001.


Collaborative Colleagues:
Tony Printezis: colleagues
Richard Jones: colleagues