InputStream.ReadNBytes Method
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Overloads
ReadNBytes(Int32) |
Reads up to a specified number of bytes from the input stream. |
ReadNBytes(Byte[], Int32, Int32) |
Reads the requested number of bytes from the input stream into the given byte array. |
ReadNBytes(Int32)
Reads up to a specified number of bytes from the input stream.
[Android.Runtime.Register("readNBytes", "(I)[B", "GetReadNBytes_IHandler", ApiSince=33)]
public virtual byte[]? ReadNBytes (int len);
[<Android.Runtime.Register("readNBytes", "(I)[B", "GetReadNBytes_IHandler", ApiSince=33)>]
abstract member ReadNBytes : int -> byte[]
override this.ReadNBytes : int -> byte[]
Parameters
- len
- Int32
the maximum number of bytes to read
Returns
a byte array containing the bytes read from this input stream
- Attributes
Remarks
Reads up to a specified number of bytes from the input stream. This method blocks until the requested number of bytes has been read, end of stream is detected, or an exception is thrown. This method does not close the input stream.
The length of the returned array equals the number of bytes read from the stream. If len
is zero, then no bytes are read and an empty byte array is returned. Otherwise, up to len
bytes are read from the stream. Fewer than len
bytes may be read if end of stream is encountered.
When this stream reaches end of stream, further invocations of this method will return an empty byte array.
Note that this method is intended for simple cases where it is convenient to read the specified number of bytes into a byte array. The total amount of memory allocated by this method is proportional to the number of bytes read from the stream which is bounded by len
. Therefore, the method may be safely called with very large values of len
provided sufficient memory is available.
The behavior for the case where the input stream is asynchronously closed, or the thread interrupted during the read, is highly input stream specific, and therefore not specified.
If an I/O error occurs reading from the input stream, then it may do so after some, but not all, bytes have been read. Consequently the input stream may not be at end of stream and may be in an inconsistent state. It is strongly recommended that the stream be promptly closed if an I/O error occurs.
Added in 11.
Java documentation for java.io.InputStream.readNBytes(int)
.
Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.
Applies to
ReadNBytes(Byte[], Int32, Int32)
Reads the requested number of bytes from the input stream into the given byte array.
[Android.Runtime.Register("readNBytes", "([BII)I", "GetReadNBytes_arrayBIIHandler", ApiSince=33)]
public virtual int ReadNBytes (byte[]? b, int off, int len);
[<Android.Runtime.Register("readNBytes", "([BII)I", "GetReadNBytes_arrayBIIHandler", ApiSince=33)>]
abstract member ReadNBytes : byte[] * int * int -> int
override this.ReadNBytes : byte[] * int * int -> int
Parameters
- b
- Byte[]
the byte array into which the data is read
- off
- Int32
the start offset in b
at which the data is written
- len
- Int32
the maximum number of bytes to read
Returns
the actual number of bytes read into the buffer
- Attributes
Remarks
Reads the requested number of bytes from the input stream into the given byte array. This method blocks until len
bytes of input data have been read, end of stream is detected, or an exception is thrown. The number of bytes actually read, possibly zero, is returned. This method does not close the input stream.
In the case where end of stream is reached before len
bytes have been read, then the actual number of bytes read will be returned. When this stream reaches end of stream, further invocations of this method will return zero.
If len
is zero, then no bytes are read and 0
is returned; otherwise, there is an attempt to read up to len
bytes.
The first byte read is stored into element b[off]
, the next one in to b[off+1]
, and so on. The number of bytes read is, at most, equal to len
. Let k be the number of bytes actually read; these bytes will be stored in elements b[off]
through b[off+
k-1]
, leaving elements b[off+
k]
through b[off+len-1]
unaffected.
The behavior for the case where the input stream is asynchronously closed, or the thread interrupted during the read, is highly input stream specific, and therefore not specified.
If an I/O error occurs reading from the input stream, then it may do so after some, but not all, bytes of b
have been updated with data from the input stream. Consequently the input stream and b
may be in an inconsistent state. It is strongly recommended that the stream be promptly closed if an I/O error occurs.
Added in 9.
Java documentation for java.io.InputStream.readNBytes(byte[], int, int)
.
Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.