Coder Social home page Coder Social logo

Thread safety about zstd HOT 4 CLOSED

facebook avatar facebook commented on July 27, 2024
Thread safety

from zstd.

Comments (4)

luben avatar luben commented on July 27, 2024

Hm, it could have be interplay of GC and locking issue. I have to test something.

from zstd.

Cyan4973 avatar Cyan4973 commented on July 27, 2024

Hi @luben .

zstd streaming interface is supposed to be thread safe.
It only uses information from local context, so as long as you have one context per thread, there is no race-condition to worry about.

from zstd.

luben avatar luben commented on July 27, 2024

Yes, I looked over the code and there is no global state. I suspect that the JVM is not resprecing the buffer pinning and it shows under GC pressure only - it moves them while compression/decompression is in progress. I have to test this and possibly allocate off-heap memory for the buffers or use the buffered version that you provide already.

from zstd.

luben avatar luben commented on July 27, 2024

Yes, it is a problem with JVM not pinning the buffers, I have confirmed. I still have to find a proper solution. Closing it now as it is not a problem of the library.

from zstd.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.