Managing memory in a computer system

US2018285251A1 · US · A1

Patent metadata
FieldValue
Publication numberUS-2018285251-A1
Application numberUS-201816002087-A
CountryUS
Kind codeA1
Filing dateJun 7, 2018
Priority dateMay 15, 2012
Publication dateOct 4, 2018
Grant date

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Methods, computer program products, and systems for managing memory in a computer system in which memory locations in use at any given time are represented as a set of memory objects in a first object graph. The first object graph includes a system root object associated by references to each of the memory objects. A method includes creating a second root object for the memory to form a second object graph for the memory. The method also includes, in response to the dereferencing of a first object from the first object graph, associating the dereferenced first object with the second object graph so that the second object graph includes at least one dereferenced object.

First claim

Opening claim text (preview).

What is claimed is: 1 . A computer program product comprising a computer readable storage medium having program code embodied therewith, the program code executable by a processor to cause the processor to perform a method comprising: identifying one or more candidate objects in a dereferenced object graph, the dereferenced object graph including a set of objects that were dereferenced from a system root object graph, the one or more candidate objects being connected objects in the dereferenced object graph; extracting dead object data from the one or more candidate objects; removing, after extracting the dead object data from the one or more candidate objects, the one or more candidate objects from memory; storing the extracted dead object data in the dereferenced object graph; and repairing the dereferenced object graph. 2 . The computer program product of claim 1 , wherein the identifying one or more candidate objects in the dereferenced object graph comprises: traversing the dereferenced object graph to identify one or more dereferenced objects in the dereferenced object graph that are marked as live, wherein the one or more candidate objects include objects in the dereferenced object graph that are not marked as live. 3 . The computer program product of claim 2 , wherein the method performed by the processor further comprises: identifying metadata objects associated with the one or more live dereferenced objects; marking the metadata objects as live; and returning, after removing the one or more candidate objects from memory, memory allocations of the one or more candidate objects to a heap. 4 . The computer program product of claim 3 , wherein the candidate objects do not include metadata objects, and wherein the metadata objects include dead information objects and field definition objects. 5 . The computer program product of claim 1 , wherein the dead object data for a candidate object includes an object identifier that identifies the candidate object, an identification of a parent object of the candidate object, and referencing field data that identifies a field in the parent object that referenced the candidate object. 6 . The computer program product of claim 5 , wherein the parent object of the candidate object is an object in the system root object graph that indirectly references the candidate object via one or more dead objects. 7 . The computer program product of claim 1 , wherein the repairing the dereferenced object graph includes removing redundant metadata objects from the dereferenced object graph. 8 . The computer program product of claim 1 , wherein the method performed by the processor further comprises: providing, by a memory manager, memory allocations from a first heap and a second heap, the first heap including storage for connected objects, the second heap including storage for a dead root object and metadata objects; and creating, in response to dereferencing an object in the first heap, a corresponding set of metadata objects in the second heap, the corresponding set of metadata objects including a cross-heap reference to the dereferenced object in the first heap. 9 . The computer program product of claim 1 , wherein the method performed by the processor further comprises: marking one or more connected objects in the system root object graph as live, wherein the one or more connected objects represent memory locations in use by a program at a given time; creating a dead root object so as to form the dereferenced object graph; and in response to a dereferencing of a first object from the system root object graph, associating the dereferenced first object with the dereferenced object graph so that the dereferenced object graph comprises one or more dereferenced objects. 10 . The computer program product of claim 1 , wherein storing the extracted dead object data in the dereferenced object graph includes replacing the one or more candidate objects in the dereferenced object graph with associated dead object data. 11 . The computer program product of claim 10 , wherein the system root object graph is associated with an application, and wherein the method performed by the processor further comprises: identifying, using the dead object data, one or more processes that created the dereferenced objects, the one or more processes being part of the application; reconstructing the system root object graph using the dead object data at a selected point in the associated processing of the application; and modifying the application to improve memory usage of the processes.

Assignees

Inventors

Classifications

  • G06F12/00Primary

    Accessing, addressing or allocating within memory systems or architectures (digital input from, or digital output to record carriers, e.g. to disk storage units, G06F3/06) · CPC title

  • Incremental or concurrent garbage collection, e.g. in real-time systems (G06F12/0261 takes precedence) · CPC title

  • Physics · mapped topic

  • Space efficiency improvement · CPC title

  • Physics · mapped topic

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US2018285251A1 cover?
Methods, computer program products, and systems for managing memory in a computer system in which memory locations in use at any given time are represented as a set of memory objects in a first object graph. The first object graph includes a system root object associated by references to each of the memory objects. A method includes creating a second root object for the memory to form a second …
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F12/00. Mapped technology areas include Physics.
When was this patent published?
Publication date Thu Oct 04 2018 00:00:00 GMT+0000 (Coordinated Universal Time) (A1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).