Comment by bluetomcat

Comment by bluetomcat 4 days ago

5 replies

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.

jstimpfle 4 days ago

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

  • rictic 3 days 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 3 days ago

    I don't see how arenas solve the problems.

    • jstimpfle 3 days ago

      You group things from the same context together, so you can free everything in a single call.