What is the best resizable circular byte buffer available in Java?
Solution 1
Not sure if it is "the best", but you have a nice example of Circular Byte buffer here.
Those Java Utilities - OstermillerUtils classes are under GPL license.
This Circular Byte Buffer implements the circular buffer producer/consumer model for bytes. Filling and emptying the buffer is done with standard Java InputStreams and OutputStreams.
Using this class is a simpler alternative to using a PipedInputStream and a PipedOutputStream.
PipedInputStreams and PipedOutputStreams don't support the mark operation, don't allow you to control buffer sizes that they use, and have a more complicated API that requires a instantiating two classes and connecting them.
Solution 2
I wonder if this one works well
We will probably try this one since it is apache license.
Solution 3
I'm using a java.util.ArrayDeque<Byte>
in a project with similar requirements. Note that you can easily change implementation using a java.util.concurrent Queue
implementation.
Solution 4
I have written such a class: ByteRingBuffer
It does not resize automatically, but there is a resize() method.
It's "well-tested" with an automatic test program, that uses random numbers to test all possible situations.
Wouter Lievens
Generalist full-stack engineer with a preference for Java and a passionate love-hate relationship towards all things frontend. Self employed working on my own product (an online political strategy game) and small part-time freelance gigs.
Updated on June 03, 2022Comments
-
Wouter Lievens about 2 years
I need a byte buffer class in Java for single-threaded use. I should be able to insert data at the back of the buffer and read data at the front, with an amortized cost of O(1). The buffer should resize when it's full, rather than throw an exception or something.
I could write one myself, but I'd be very surprised if this didn't exist yet in a standard Java package, and if it doesn't, I'd expect it to exist in some well-tested public library.
What would you recommend?
-
VonC over 15 yearsIt has a private resize method that you can easily adapt to your dynamic resize need, or an 'infinite' mode which means it will always grow.
-
-
paxdiablo over 15 yearsThat's not bad. It's not resizable, and it's GPL so you have to watch out for licensing issues but it would be a good start.
-
VonC over 15 yearsIt has a private resize method that you can easily adapt to your dynamic resize need.
-
paxdiablo over 15 years@Wouter, it will always be blocking at some point (if you can't allocate more memory for the bytes), so you'd have to code for that anyway.
-
Wouter Lievens over 15 years@Pax: you mean when you're out of memory? That line of thinking would go for any resizable container. Or am I misunderstanding?
-
paxdiablo over 15 yearsNot misunderstanding. I'm saying, since you have to code for a limit of some sort, it makes little difference between 100, 10,000 or the extent of memory (in terms of coding effort). Although I understand that resizable gives the best tradeoff between initial size and maximum capability.
-
Vishy over 14 yearsYou might find that using Byte instead of byte is a significant perform hit. ;)
-
Jus12 about 13 yearshas anyone used the OstermillerUtils for bytebuffer? Please give some feedback.
-
Martin about 7 yearsThis is a very inefficient byte buffer, not only because the overhead in not using primitives. Try something backed by a byte[] instead.
-
Benjamin Gruenbaum almost 7 yearsIt is not resizable