[−][src]Crate zerogc
Zero overhead tracing garbage collection for rust, by abusing the borrow checker.
Features
- Easy to use, since
Gc<T>isCopyand coerces to a reference. - Absolutely zero overhead when modifying pointers, since
Gc<T>isCopy. - Implementation agnostic API
- Unsafe code has complete freedom to manipulate garbage collected pointers, and it doesn't need to understand the distinction
- Uses rust's lifetime system to ensure all roots are known at explicit safepoints, without any runtime overhead.
- Collection can only happen with an explicit
safepointcall and has no overhead between these calls, - API supports moving objects (allowing copying/generational GCs)
Modules
| cell | Implements a GcCell to allow mutating values inside garbage collected objects. |
| prelude | The prelude for |
Macros
| freeze_context | Indicate its safe to begin a garbage collection (like safepoint!) and then "freeze" the specified context. |
| safepoint | Indicate it's safe to begin a garbage collection, while keeping the specified root alive. |
| safepoint_recurse | Invoke the closure with a temporary GcContext, then perform a safepoint afterwards. |
| unfreeze_context | Unfreeze the context, allowing it to be used again |
| unsafe_gc_brand | Unsafely assume that the generic implementation of GcBrand is valid, if and only if it's valid for the generic lifetime and type parameters. |
| unsafe_immutable_trace_iterable | Unsafely implement |
| unsafe_trace_deref | Unsafely implement |
| unsafe_trace_lock | Unsafely implement |
| unsafe_trace_primitive | Unsafely implement |
Structs
| AssumeNotTraced | A wrapper type that assumes its contents don't need to be traced |
Traits
| GcBindHandle | Trait for binding GcHandles to contexts using GcBindHandle::bind_to |
| GcBrand | Changes all references to garbage
collected objects to match |
| GcContext | The context of garbage collection, which can be frozen at a safepoint. |
| GcCreateHandle | |
| GcDirectBarrier | Safely trigger a write barrier before writing to a garbage collected value. |
| GcHandle | A owned handle which points to a garbage collected object. |
| GcRef | A garbage collected pointer to a value. |
| GcSafe | Indicates that a type can be safely allocated by a garbage collector. |
| GcSimpleAlloc | A simple interface to allocating from a GcContext. |
| GcSystem | A garbage collector implementation. |
| GcVisitor | Visits garbage collected objects |
| NullTrace | Marker types for types that don't need to be traced |
| Trace | Indicates that a type can be traced by a garbage collector. |
| TraceImmutable | A type that can be safely traced/relocated without having to use a mutable reference |