Garbage Collection (computer Science) - Principles

Principles

The basic principles of garbage collection are:

  1. Find data objects in a program that cannot be accessed in the future
  2. Reclaim the resources used by those objects

Many computer languages require garbage collection, either as part of the language specification (e.g., Java, C#, and most scripting languages) or effectively for practical implementation (e.g., formal languages like lambda calculus); these are said to be garbage collected languages. Other languages were designed for use with manual memory management, but have garbage collected implementations available (e.g., C, C++). Some languages, like Ada, Modula-3, and C++/CLI allow both garbage collection and manual memory management to co-exist in the same application by using separate heaps for collected and manually managed objects; others, like D, are garbage collected but allow the user to manually delete objects and also entirely disable garbage collection when speed is required. While integrating garbage collection into the language's compiler and runtime system enables a much wider choice of methods, post hoc GC systems exist, including some that do not require recompilation. (Post-hoc GC is sometimes distinguished as litter collection.) The garbage collector will almost always be closely integrated with the memory allocator.

Read more about this topic:  Garbage Collection (computer Science)

Famous quotes containing the word principles:

    [E]very thing is useful which contributes to fix us in the principles and practice of virtue.
    Thomas Jefferson (1743–1826)

    To abandon oneself to principles is really to die—and to die for an impossible love which is the contrary of love.
    Albert Camus (1913–1960)

    In her present ignorance, woman’s religion, instead of making her noble and free, by the wrong application of great principles of right and justice, has made her bondage but more certain and lasting, her degradation more hopeless and complete.
    Elizabeth Cady Stanton (1815–1902)