OracleBFile.Read(Byte[], Int32, Int32) Método

Definición

Lee una secuencia de bytes en la secuencia OracleBFile actual y hace avanzar la posición dentro de la secuencia en función del número de bytes leídos.Reads a sequence of bytes from the current OracleBFile stream and advances the position within the stream by the number of bytes read.

public:
 override int Read(cli::array <System::Byte> ^ buffer, int offset, int count);
public override int Read (byte[] buffer, int offset, int count);
override this.Read : byte[] * int * int -> int
Public Overrides Function Read (buffer As Byte(), offset As Integer, count As Integer) As Integer

Parámetros

buffer
Byte[]

Matriz de bytes.An array of bytes. Cuando este método devuelve un valor, el búfer contiene la matriz de bytes especificada con valores entre offset y (offset + count) reemplazada por los bytes leídos desde el origen actual.When this method returns, the buffer contains the specified byte array with the values between offset and (offset + count) replaced by the bytes read from the current source.

offset
Int32

Posición de desplazamiento en bytes de base cero de buffer donde se comienza a almacenar los datos leídos de la secuencia actual.The zero-based byte offset in buffer at which to begin storing the data read from the current stream.

count
Int32

Número máximo de bytes que se deben leer de la secuencia actual.The maximum number of bytes to be read from the current stream.

Devoluciones

Número total de bytes leídos en el búfer.The total number of bytes read into the buffer. Puede ser menor que el número de bytes solicitado si dicho número de bytes no está disponible en la actualidad, o cero si se ha alcanzado el final del archivo.This may be less than the number of bytes requested if that many bytes are not currently available, or zero if the end of the file has been reached.

Excepciones

La suma de offset y count es mayor que la longitud del búfer.The sum of offset and count is larger than the buffer length.

buffer es una referencia nula (Nothing en Visual Basic).buffer is a null reference (Nothing in Visual Basic).

offset o count es negativo.offset or count is negative.

La conexión a la que está asociado BFILE está cerrada.The connection with which a BFILE is associated is closed.

Error de E/S.An I/O error occurred.

Se llamó a algún método después de cerrar o desechar la secuencia.Methods were called after the stream was closed or disposed.

Comentarios

El Read método lee un máximo de count bytes de la buffer secuencia actual y los offsetalmacena a partir de.The Read method read a maximum of count bytes from the current stream and store them in buffer beginning at offset. La posición actual dentro de la secuencia se avanza por el número de bytes leídos; sin embargo, si se produce una excepción, la posición actual dentro de la secuencia permanece sin cambios.The current position within the stream is advanced by the number of bytes read; however, if an exception occurs, the current position within the stream remains unchanged. ReadDevuelve el número de bytes leídos.Read returns the number of bytes read. El valor devuelto es cero solo si la posición está actualmente al final de la secuencia.The return value is zero only if the position is currently at the end of the stream. Readse bloqueará hasta que se pueda leer al menos un byte de datos, en caso de que no haya datos disponibles.Read will block until at least one byte of data can be read, in the event that no data is available. Readdevuelve 0 solo cuando se ha alcanzado el final del archivo.Read returns 0 only when the end of the file has been reached. Reades gratis para devolver menos bytes de los solicitados, incluso si no se ha alcanzado el final de la secuencia.Read is free to return fewer bytes than requested even if the end of the stream has not been reached.

Cualquier intento de obtener acceso a OracleBFile un cerrado Read mediante Seek los métodos o vuelve a OracleBFile abrir automáticamente un flujo.Any attempt to access a closed OracleBFile using the Read or Seek methods reopens an OracleBFile stream automatically.

En el C# ejemplo siguiente se da por supuesto este esquema en una tabla de Oracle:The following C# example assumes this schema in an Oracle table:

(col1 number, col2 BFILE)  

En el ejemplo se muestra Read el Seek uso de los métodos OracleBFile y para tener acceso a un objeto.The example demonstrates using the Read and Seek methods to access an OracleBFile object.

byte[] buffer = new byte[100];  
OracleDataReader dataReader = command.ExecuteReader();  
using (dataReader) {  
    if (dataReader.Read()) {  
            OracleBFile BFile = dataReader.GetOracleBFile(1);  
        using (BFile) {  
            BFile.Seek(0, SeekOrigin.Begin);  
            BFile.Read(buffer, 0, 100);  
        }  
    }  
}  

Se aplica a