Class UnsafeByteOperations
- java.lang.Object
-
- com.google.protobuf.UnsafeByteOperations
-
@ExperimentalApi public final class UnsafeByteOperations extends java.lang.Object
Provides a number of unsafe byte operations to be used by advanced applications with high performance requirements. These methods are referred to as "unsafe" because they potentially expose the backing buffer of aByteString
to the application.DISCLAIMER: The methods in this class should only be called if it is guaranteed that the buffer backing the
ByteString
will never change! Mutation of aByteString
can lead to unexpected and undesirable consequences in your application, and will likely be difficult to debug. Proceed with caution!This can have a number of significant side effects that have spooky-action-at-a-distance-like behavior. In particular, if the bytes value changes out from under a Protocol Buffer:
- serialization may throw
- serialization may succeed but the wrong bytes may be written out
- messages are no longer threadsafe
- hashCode may be incorrect
- can result in a permanent memory leak when used as a key in a long-lived HashMap
- the semantics of many programs may be violated if this is the case
-
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static ByteString
unsafeWrap(byte[] buffer)
An unsafe operation that returns aByteString
that is backed by the provided buffer.static ByteString
unsafeWrap(byte[] buffer, int offset, int length)
An unsafe operation that returns aByteString
that is backed by a subregion of the provided buffer.static ByteString
unsafeWrap(java.nio.ByteBuffer buffer)
An unsafe operation that returns aByteString
that is backed by the provided buffer.static void
unsafeWriteTo(ByteString bytes, ByteOutput output)
Writes the givenByteString
to the providedByteOutput
.
-
-
-
Method Detail
-
unsafeWrap
public static ByteString unsafeWrap(byte[] buffer)
An unsafe operation that returns aByteString
that is backed by the provided buffer.- Parameters:
buffer
- the buffer to be wrapped- Returns:
- a
ByteString
backed by the provided buffer
-
unsafeWrap
public static ByteString unsafeWrap(byte[] buffer, int offset, int length)
An unsafe operation that returns aByteString
that is backed by a subregion of the provided buffer.- Parameters:
buffer
- the buffer to be wrappedoffset
- the offset of the wrapped regionlength
- the number of bytes of the wrapped region- Returns:
- a
ByteString
backed by the provided buffer
-
unsafeWrap
public static ByteString unsafeWrap(java.nio.ByteBuffer buffer)
An unsafe operation that returns aByteString
that is backed by the provided buffer.- Parameters:
buffer
- the Java NIO buffer to be wrapped- Returns:
- a
ByteString
backed by the provided buffer
-
unsafeWriteTo
public static void unsafeWriteTo(ByteString bytes, ByteOutput output) throws java.io.IOException
Writes the givenByteString
to the providedByteOutput
. Calling this method may result in multiple operations on the targetByteOutput
(i.e. for ropedByteString
s).This method exposes the internal backing buffer(s) of the
ByteString
to theByteOutput
in order to avoid additional copying overhead. It would be possible for a maliciousByteOutput
to corrupt theByteString
. Use with caution!NOTE: The
ByteOutput
MUST NOT modify the provided buffers. Doing so may result in corrupted data, which would be difficult to debug.- Parameters:
bytes
- theByteString
to be writtenoutput
- the output to receive the bytes- Throws:
java.io.IOException
- if an I/O error occurs
-
-