Stream.ReadExactlyAsync 方法

定义

重载

ReadExactlyAsync(Memory<Byte>, CancellationToken)

从当前流异步读取字节,推进流中的位置,直到 buffer 填充,并监视取消请求。

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

从当前流异步读取 count 字节数,推进流中的位置,并监视取消请求。

ReadExactlyAsync(Memory<Byte>, CancellationToken)

Source:
Stream.cs
Source:
Stream.cs
Source:
Stream.cs

从当前流异步读取字节,推进流中的位置,直到 buffer 填充,并监视取消请求。

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

参数

buffer
Memory<Byte>

要写入数据的缓冲区。

cancellationToken
CancellationToken

要监视取消请求的标记。

返回

表示异步读取操作的任务。

例外

在填充 buffer之前到达流的末尾。

取消令牌已取消。 此异常存储在返回的任务中。

注解

如果 buffer 为空,则无需等待流中的可用数据即可完成此读取操作。

适用于

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

Source:
Stream.cs
Source:
Stream.cs
Source:
Stream.cs

从当前流异步读取 count 字节数,推进流中的位置,并监视取消请求。

public System.Threading.Tasks.ValueTask ReadExactlyAsync (byte[] buffer, int offset, int count, System.Threading.CancellationToken cancellationToken = default);
member this.ReadExactlyAsync : byte[] * int * int * System.Threading.CancellationToken -> System.Threading.Tasks.ValueTask
Public Function ReadExactlyAsync (buffer As Byte(), offset As Integer, count As Integer, Optional cancellationToken As CancellationToken = Nothing) As ValueTask

参数

buffer
Byte[]

要写入数据的缓冲区。

offset
Int32

buffer 中的字节偏移量,从该偏移量开始写入从流中读取的数据。

count
Int32

要从当前流中读取的字节数。

cancellationToken
CancellationToken

要监视取消请求的标记。

返回

表示异步读取操作的任务。

例外

buffernull

offsetbuffer 的界限外。

- 或 -

count 为负数。

count 的组合offset指定的范围超过了 的buffer长度。

在读取 count 字节数之前到达流的末尾。

取消令牌已取消。 此异常存储在返回的任务中。

注解

当 为 0 (零) 时 count ,此读取操作将完成,而无需等待流中的可用数据。

此方法将存储在任务中,它返回该方法的同步对应项可能引发的所有非使用异常。 如果异常存储在返回的任务中,则在等待任务时将引发该异常。 使用异常(如 ArgumentException)仍会同步引发。 有关存储的异常,请参阅 引发的 ReadExactly(Byte[], Int32, Int32)异常。

适用于