top | item 45536677

(no title)

bluetomcat | 4 months ago

Because in C, every allocation incurs a responsibility to track its lifetime and to know who will eventually free it. Copying and moving buffers is also prone to overflows, off-by-one errors, etc. The generic memory allocator is a smart but unpredictable complex beast that lives in your address space and can mess your CPU cache, can introduce undesired memory fragmentation, etc.

In Java, you don't care because the GC cleans after you and you don't usually care about millisecond-grade performance.

discuss

order

jstimpfle|4 months ago

No. Look up Arenas. In general group allocations to avoid making a mess.

rictic|4 months ago

If you send a task off to a work queue in another thread, and then do some local processing on it, you can't usually use a single Arena, unless the work queue itself is short lived.

jenadine|4 months ago

I don't see how arenas solve the problems.

estimator7292|4 months ago

No. Arenas are not a general case solution. Look it up