Class BufferOutputStream

    • Constructor Detail

      • BufferOutputStream

        public BufferOutputStream​(MemoryManager mm)
        Creates the BufferOutputStream without initial Buffer. Created BufferOutputStream won't use "reallocate" strategy, which means if internal Buffer window gets overloaded - it will be appended to the CompositeBuffer and new window will be allocated.
        Parameters:
        mm - MemoryManager
      • BufferOutputStream

        public BufferOutputStream​(MemoryManager mm,
                                  Buffer buffer)
        Creates the BufferOutputStream using passed Buffer as initial. Created BufferOutputStream won't use "reallocate" strategy, which means if internal Buffer window gets overloaded - it will be appended to the CompositeBuffer and new window will be allocated.
        Parameters:
        mm - MemoryManager
        buffer - initial Buffer
      • BufferOutputStream

        public BufferOutputStream​(MemoryManager mm,
                                  Buffer buffer,
                                  boolean reallocate)
        Creates the BufferOutputStream using passed Buffer as initial. Created BufferOutputStream can choose whether use or not "reallocate" strategy. Using "reallocate" strategy means following: if internal Buffer window gets overloaded - it will be reallocated using MemoryManager.reallocate(org.glassfish.grizzly.Buffer, int), which may lead to extra memory allocation and bytes copying (bigger memory chunk might be allocated to keep original stream data plus extra data been written to stream), the benefit of this is that stream data will be located in the single memory chunk. If we don't use "reallocate" strategy - when internal Buffer gets overloaded it will be appended to the CompositeBuffer and new window Buffer will be allocated then.
        Parameters:
        mm - MemoryManager
        buffer - initial Buffer