Skip to content

Latest commit

 

History

History
85 lines (72 loc) · 2.71 KB

garbage collection.md

File metadata and controls

85 lines (72 loc) · 2.71 KB

Garbage Collection

Garbage collection (GC) is a form of automatic memory management. The garbage collector, or just collector, attempts to reclaim garbage, or memory occupied by objects that are no longer in use by the program. In large servers sometimes there is a GC pause to reclaim memory.

  • Java compilation and execution goes through the below steps
    • JAVA Source File
    • Static Compiler
    • Class file
    • Runtime (JVM)
    • Bytecode Verifier
    • JIT compiler
    • Garbage Collection

Creating a new programming language

  • Get your syntax right

  • Make an interpreter

  • Static Compilation

  • Then give that to JVM

  • Usage Tradeoff

    • Highly Engineered Perforamant System - Exact and Tracing
      • Java, .NET
    • Non-Performance Critical - Reference Counting and Conservative
      • PHP, Python
  • GC Fundamental

    • Allocation
    • Identification
    • Reclamation
  • Allocator

    • Free list
      • Class-Based Object Allocation
    • Bump counting
      • It's just a full heap. Allocation by incrementing pointer
  • Identification

    • Tracing (Mark and Sweep)
      • Start from the top (DFS). Those which are not reached garbage collected
      • Know about full heap
    • Reference Counting
      • Incoming reference count
      • Know about one object
  • Reclamation

    • Sweep to Free
    • Defragment Compaction > Mark compact
    • Evacuate
  • Garbage Collector Algorithms

  • Mark and Sweep

    • Free List + trace + Sweep to free
  • Mark Compact

    • Bump Allocation + trace + Compact
  • Semi Space

    • Bump Allocation + trace + Evacuate
    • Half memory + Auto defragmented
  • When choosing

    • Make the common case fast
    • Young objects die early
    • Two generational object tracing space
      • Nursery
      • Mature
  • Immix

    • An upper-level hierarchy
    • Decrease checking
  • Most object size 8-16 bytes

  • Specification in software. Never think about implementation.

  • Reference counting is 30% slower than tracing

  • RC immix - rust - bitc

  • Tracing > cant identify dead objects only live

  • Concurrent real-time system garbage collection

  • Example

    • Mostly copying collector - Apple UI Kit
    • BDW collector - Chakra VM - Mark sweep - Free list

References