CryptoStream.ReadAsync(Byte[], Int32, Int32, CancellationToken) Metod

Definition

Läser en sekvens med byte från den aktuella strömmen asynkront, avancerar positionen i strömmen med antalet lästa byte och övervakar begäranden om annullering.

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>
abstract member ReadAsync : byte[] * int * int * System.Threading.CancellationToken -> System.Threading.Tasks.Task<int>
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)

Parametrar

buffer
Byte[]

Bufferten som data ska skrivas till.

offset
Int32

Byteförskjutningen buffer där du börjar skriva data från dataströmmen.

count
Int32

Det maximala antalet byte som ska läsas.

cancellationToken
CancellationToken

Token som ska övervakas för annulleringsbegäranden. Standardvärdet är None.

Returer

En uppgift som representerar den asynkrona läsåtgärden. Värdet för aktivitetsobjektets TResult parameter innehåller det totala antalet byte som lästs in i bufferten. Resultatet kan vara mindre än antalet begärda byte om antalet tillgängliga byte för närvarande är mindre än det begärda talet, eller om det kan vara 0 (noll) om strömmens slut har nåtts.

Undantag

buffer är null.

offset eller count är negativ.

Summan av offset och count är större än buffertlängden.

Strömmen stöder inte läsning.

Strömmen har tagits bort.

Strömmen används för närvarande av en tidigare läsåtgärd.

Annulleringstoken avbröts. Det här undantaget lagras i den returnerade aktiviteten.

Kommentarer

Important

Från och med .NET 6 kanske den här metoden inte läser så många byte som begärdes. Mer information finns i Del- och nollbyteläsningar i DeflateStream, GZipStream och CryptoStream.

Du måste förorda anropet till ReadAsync med operatorn await (C#) eller Await (Visual Basic) för att avbryta körningen av metoden tills uppgiften har slutförts. Mer information finns i Asynkron programmering (C#) eller Synkron programmering med Async och Await (Visual Basic).

Om åtgärden avbryts innan den slutförs innehåller Canceled den returnerade aktiviteten värdet för Status egenskapen.

Den här metoden lagrar i aktiviteten som returnerar alla undantag som inte används som metodens synkrona motsvarighet kan utlösa. Om ett undantag lagras i den returnerade aktiviteten utlöses undantaget när aktiviteten väntar. Användningsfel, till exempel ArgumentException, genereras fortfarande synkront. De lagrade undantagen finns i undantagen som genereras av Read(Byte[], Int32, Int32).

Gäller för

Se även