Condividi tramite


CryptoStream.ReadAsync Metodo

Definizione

Overload

Nome Descrizione
ReadAsync(Byte[], Int32, Int32, CancellationToken)

Legge una sequenza di byte dal flusso corrente in modo asincrono, sposta in avanti la posizione all'interno del flusso in base al numero di byte letti e monitora le richieste di annullamento.

ReadAsync(Memory<Byte>, CancellationToken)

Legge in modo asincrono una sequenza di byte dal flusso corrente, sposta in avanti la posizione all'interno del flusso in base al numero di byte letti e monitora le richieste di annullamento.

ReadAsync(Byte[], Int32, Int32, CancellationToken)

Origine:
CryptoStream.cs
Origine:
CryptoStream.cs
Origine:
CryptoStream.cs
Origine:
CryptoStream.cs
Origine:
CryptoStream.cs

Legge una sequenza di byte dal flusso corrente in modo asincrono, sposta in avanti la posizione all'interno del flusso in base al numero di byte letti e monitora le richieste di annullamento.

public:
 override System::Threading::Tasks::Task<int> ^ ReadAsync(cli::array <System::Byte> ^ buffer, int offset, int count, System::Threading::CancellationToken cancellationToken);
public override System.Threading.Tasks.Task<int> ReadAsync(byte[] buffer, int offset, int count, System.Threading.CancellationToken cancellationToken);
override this.ReadAsync : byte[] * int * int * System.Threading.CancellationToken -> System.Threading.Tasks.Task<int>
Public Overrides Function ReadAsync (buffer As Byte(), offset As Integer, count As Integer, cancellationToken As CancellationToken) As Task(Of Integer)

Parametri

buffer
Byte[]

Buffer in cui scrivere i dati.

offset
Int32

Offset di byte in in buffer corrispondenza del quale iniziare a scrivere dati dal flusso.

count
Int32

Numero massimo di byte da leggere.

cancellationToken
CancellationToken

Token da monitorare per le richieste di annullamento. Il valore predefinito è None.

Restituisce

Attività che rappresenta l'operazione di lettura asincrona. Il valore del parametro dell'oggetto TResult attività contiene il numero totale di byte letti nel buffer. Il risultato può essere minore del numero di byte richiesti se il numero di byte attualmente disponibili è minore del numero richiesto oppure può essere 0 (zero) se è stata raggiunta la fine del flusso.

Eccezioni

buffer è null.

offset o count è negativo.

La somma di offset e count è maggiore della lunghezza del buffer.

Il flusso non supporta la lettura.

Il flusso è stato eliminato.

Il flusso è attualmente in uso da un'operazione di lettura precedente.

Il token di annullamento è stato annullato. Questa eccezione viene archiviata nell'attività restituita.

Commenti

Importante

A partire da .NET 6, questo metodo potrebbe non leggere il numero di byte richiesto. Per altre informazioni, vedere Letture di byte parziali e zero in DeflateStream, GZipStream e CryptoStream.

È necessario anteporre la chiamata a ReadAsync con l'operatore await (C#) o Await (Visual Basic) per sospendere l'esecuzione del metodo fino al completamento dell'attività. Per altre informazioni, vedere Programmazione asincrona (C#) o Programmazione asincrona con Async e Await (Visual Basic).

Se l'operazione viene annullata prima del completamento, l'attività restituita contiene il Canceled valore per la Status proprietà .

Questo metodo archivia nell'attività che restituisce tutte le eccezioni non di utilizzo che la controparte sincrona del metodo può generare. Se un'eccezione viene archiviata nell'attività restituita, tale eccezione verrà generata quando l'attività è attesa. Le eccezioni di utilizzo, ad esempio ArgumentException, vengono comunque generate in modo sincrono. Per le eccezioni archiviate, vedere le eccezioni generate da Read(Byte[], Int32, Int32).

Vedi anche

Si applica a

ReadAsync(Memory<Byte>, CancellationToken)

Origine:
CryptoStream.cs
Origine:
CryptoStream.cs
Origine:
CryptoStream.cs
Origine:
CryptoStream.cs
Origine:
CryptoStream.cs

Legge in modo asincrono una sequenza di byte dal flusso corrente, sposta in avanti la posizione all'interno del flusso in base al numero di byte letti e monitora le richieste di annullamento.

public override System.Threading.Tasks.ValueTask<int> ReadAsync(Memory<byte> buffer, System.Threading.CancellationToken cancellationToken = default);
override this.ReadAsync : Memory<byte> * System.Threading.CancellationToken -> System.Threading.Tasks.ValueTask<int>
Public Overrides Function ReadAsync (buffer As Memory(Of Byte), Optional cancellationToken As CancellationToken = Nothing) As ValueTask(Of Integer)

Parametri

buffer
Memory<Byte>

Area di memoria in cui scrivere i dati.

cancellationToken
CancellationToken

Token da monitorare per le richieste di annullamento. Il valore predefinito è None.

Restituisce

Attività che rappresenta l'operazione di lettura asincrona. Il valore della proprietà Result contiene il numero totale di byte letti nel buffer. Il valore del risultato può essere minore del numero di byte allocati nel buffer se tale numero di byte non è attualmente disponibile oppure può essere 0 (zero) se è stata raggiunta la fine del flusso.

Eccezioni

L'oggetto CryptoStreamMode associato all'oggetto corrente CryptoStream non corrisponde al flusso sottostante. Ad esempio, questa eccezione viene generata quando si usa Read con un flusso sottostante che viene scritto solo.

Il token di annullamento è stato annullato. Questa eccezione viene archiviata nell'attività restituita.

Commenti

A partire da .NET 6, questo metodo potrebbe non leggere il numero di byte richiesto. Per altre informazioni, vedere Letture di byte parziali e zero in DeflateStream, GZipStream e CryptoStream.

Si applica a