次の方法で共有


CryptoStream.EndRead(IAsyncResult) メソッド

定義

保留中の非同期読み取りが完了するまで待機します。 (代わりに、ReadAsync の使用を検討してください。)

public:
 override int EndRead(IAsyncResult ^ asyncResult);
public override int EndRead (IAsyncResult asyncResult);
override this.EndRead : IAsyncResult -> int
Public Overrides Function EndRead (asyncResult As IAsyncResult) As Integer

パラメーター

asyncResult
IAsyncResult

終了させる保留状態の非同期リクエストへの参照。

戻り値

ストリームから読み取ったバイト数 (0 ~要求したバイト数の間の数値)。 ゼロ (0) が返されるのは、ストリームの末尾で読み取ろうとしたときだけです。それ以外の場合は、少なくとも 1 バイトが読み込み可能になるまでブロックします。

例外

asyncResultnullです。

保留中の読み取り操作へのハンドルは使用できません。

- または -

保留中の操作は読み取りをサポートしていません。

asyncResult は現在のストリームの BeginRead(Byte[], Int32, Int32, AsyncCallback, Object) メソッドから取得されませんでした。

ストリームが閉じているか、内部エラーが発生しました。

注釈

.NET Framework 4 およびそれ以前のバージョンで非同期 I/O 操作を実装するには、BeginReadEndRead などのメソッドを使用する必要があります。 これらのメソッドは、レガシ コードをサポートするために現在のバージョンで引き続き使用できます。ただし、、、 などのReadAsyncWriteAsyncCopyToAsyncFlushAsync新しい非同期メソッドは、非同期 I/O 操作をより簡単に実装するのに役立ちます。

ストリームから読み取られたバイト数を確認するには、 を呼び出 EndRead します。

EndReadは、 からBeginReadごとに IAsyncResult 1 回呼び出すことができます。

このメソッドは、I/O 操作が完了するまでブロックします。

適用対象