Report a bug
If you spot a problem with this page, click here to create a Bugzilla issue.
Improve this page
Quickly fork, edit online, and submit a pull request for this page.
Requires a signed-in GitHub account. This works well for small changes.
If you'd like to make larger changes you may want to consider using
a local clone.
std.experimental.allocator.gc_allocator
D's built-in garbage-collected allocator.
- struct
GCAllocator
; - D's built-in garbage-collected allocator.Examples:
auto buffer = GCAllocator.instance.allocate(1024 * 1024 * 4); // deallocate upon scope's end (alternatively: leave it to collection) scope(exit) GCAllocator.instance.deallocate(buffer); //...
- enum uint
alignment
; - The
alignment
is a static constant equal to platformAlignment, which ensures properalignment
for any D data type. - shared pure nothrow @trusted void[]
allocate
(size_tbytes
);
shared pure nothrow @trusted boolexpand
(ref void[]b
, size_tdelta
);
shared pure nothrow @system boolreallocate
(ref void[]b
, size_tnewSize
);
shared pure nothrow @nogc @trusted TernaryresolveInternalPointer
(const void*p
, ref void[]result
);
shared pure nothrow @nogc @system booldeallocate
(void[]b
);
shared pure nothrow @nogc @safe size_tgoodAllocSize
(size_tn
); - Standard allocator methods per the semantics defined above. The
deallocate
andreallocate
methods are @system because they may move memory around, leaving dangling pointers in user code. - static shared GCAllocator
instance
; - Returns the global
instance
of this allocator type. The garbage collected allocator is thread-safe, therefore all of its methods andinstance
itself are shared.
Copyright © 1999-2018 by the D Language Foundation | Page generated by
Ddoc on Tue Mar 13 17:32:35 2018