TY - GEN
T1 - Tag-free garbage collection for strongly typed programming languages
AU - Goldberg, Benjamin
N1 - Funding Information:
Email: [email protected] This research was funded in part by the National Science Foundation (#CCR-8909634) and by DARPA/ONR (#NOOO14-90-l110).
Funding Information:
This research was funded in part by the National Science Foundation (#CCR-8909634) and by DARPA/ONR (#N00014-90-1110).
Funding Information:
I would like to thank the National Science Foundation and DARPA for supporting this work. I would also like to thank Robert Dewar, Fritz Henglein, Malcolm Harrison, Konstantin Liiufer, Gary Lindstrom, Andrew Appel, and Di-anne Britton for their assistance.
Publisher Copyright:
© 1991 ACM.
PY - 1991/5/1
Y1 - 1991/5/1
N2 - With the emergence of a number of strongly typed languages with very dynamic storage allocation, efficient methods of storage reclamation have become especially important. Even though no type tags are required for type checking programs written in these languages, current implementations do use tags to support run time garbage collection. This often inflicts a high time and space overhead on program execution. Since the early days of LISP (and Algol68 later on), there have been schemes for performing tag-free garbage collection. In this paper, we describe an improvement of existing methods that leads to more effective storage reclamation in the absence of tags. Garbage collection has also traditionally been viewed as being independent of the particular program being executed. This means that results of compile-time analyses which could increase the effectiveness of garbage collection cannot be incorporated easily into the garbage collection process. This paper describes a method for performing garbage collection 1) in the absence of tagged data, and 2) using compile-time information. This method relies on compiler-generated garbage collection routines specific to the program being executed and incurs no time overhead during execution other then the cost of the garbage collection process itself. We describe tag-free garbage collection methods for monomorphically typed and polymorphically typed languages, and suggest how they might be extended to support parallel languages.
AB - With the emergence of a number of strongly typed languages with very dynamic storage allocation, efficient methods of storage reclamation have become especially important. Even though no type tags are required for type checking programs written in these languages, current implementations do use tags to support run time garbage collection. This often inflicts a high time and space overhead on program execution. Since the early days of LISP (and Algol68 later on), there have been schemes for performing tag-free garbage collection. In this paper, we describe an improvement of existing methods that leads to more effective storage reclamation in the absence of tags. Garbage collection has also traditionally been viewed as being independent of the particular program being executed. This means that results of compile-time analyses which could increase the effectiveness of garbage collection cannot be incorporated easily into the garbage collection process. This paper describes a method for performing garbage collection 1) in the absence of tagged data, and 2) using compile-time information. This method relies on compiler-generated garbage collection routines specific to the program being executed and incurs no time overhead during execution other then the cost of the garbage collection process itself. We describe tag-free garbage collection methods for monomorphically typed and polymorphically typed languages, and suggest how they might be extended to support parallel languages.
UR - http://www.scopus.com/inward/record.url?scp=85029645630&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=85029645630&partnerID=8YFLogxK
U2 - 10.1145/113445.113460
DO - 10.1145/113445.113460
M3 - Conference contribution
AN - SCOPUS:85029645630
SN - 0897914287
T3 - Proceedings of the ACM SIGPLAN Conference on Programming Language Design and Implementation (PLDI)
SP - 165
EP - 176
BT - Proceedings of the ACM SIGPLAN Conference on Programming Language Design and Implementation (PLDI)
PB - Association for Computing Machinery
T2 - 1991 ACM SIGPLAN 1991 Conference on Programming Language Design and Implementation, PLDI 1991
Y2 - 24 June 1991 through 28 June 1991
ER -