Stream.Dispose Stream.Dispose Stream.Dispose Stream.Dispose Method

定義

この Stream オブジェクトによって使用されているすべてのリソースを解放します。Releases all resources used by the Stream object.

オーバーロード

Dispose() Dispose() Dispose() Dispose()

Stream によって使用されているすべてのリソースを解放します。Releases all resources used by the Stream.

Dispose(Boolean) Dispose(Boolean) Dispose(Boolean) Dispose(Boolean)

Stream によって使用されているアンマネージド リソースを解放し、オプションでマネージド リソースも解放します。Releases the unmanaged resources used by the Stream and optionally releases the managed resources.

Dispose() Dispose() Dispose() Dispose()

Stream によって使用されているすべてのリソースを解放します。Releases all resources used by the Stream.

public:
 virtual void Dispose();
public void Dispose ();
abstract member Dispose : unit -> unit
override this.Dispose : unit -> unit
Public Sub Dispose ()

実装

注釈

このメソッドは、バッキング ストアに変更を作成し、リソースを解放するストリームを閉じると、ストリームを破棄します。This method disposes the stream, by writing any changes to the backing store and closing the stream to release resources.

呼び出すDisposeによって使用されるリソースの使用、Stream他の目的で再割り当てします。Calling Dispose allows the resources used by the Stream to be reallocated for other purposes. 詳細についてはDisposeを参照してくださいアンマネージ リソースのクリーンアップします。For more information about Dispose, see Cleaning Up Unmanaged Resources.

注意 (継承者)

ストリーム オブジェクトのすべてのクリーンアップ ロジックを配置Dispose(Boolean)します。Place all cleanup logic for your stream object in Dispose(Boolean). オーバーライドしないClose()します。Do not override Close().

旧バージョンと互換性の要件によりこのメソッドの実装が Dispose パターンの推奨されるガイダンスと異なることに注意してください。Note that because of backward compatibility requirements, this method's implementation differs from the recommended guidance for the Dispose pattern. このメソッドを呼び出すClose()、呼び出すDispose(Boolean)します。This method calls Close(), which then calls Dispose(Boolean).

Dispose(Boolean) Dispose(Boolean) Dispose(Boolean) Dispose(Boolean)

Stream によって使用されているアンマネージド リソースを解放し、オプションでマネージド リソースも解放します。Releases the unmanaged resources used by the Stream and optionally releases the managed resources.

protected:
 virtual void Dispose(bool disposing);
protected virtual void Dispose (bool disposing);
abstract member Dispose : bool -> unit
override this.Dispose : bool -> unit
Protected Overridable Sub Dispose (disposing As Boolean)

パラメーター

disposing
Boolean Boolean Boolean Boolean

マネージド リソースとアンマネージド リソースの両方を解放する場合は true。アンマネージド リソースだけを解放する場合は falsetrue to release both managed and unmanaged resources; false to release only unmanaged resources.

注釈

指定することで、すべてのリソースを解放する必要がありますtruedisposingします。You should release all resources by specifying true for disposing. ときにdisposingtrue、ストリーム データは、基になるバッファーにフラッシュされ、ファイナライズ可能なその他のオブジェクトへのアクセスを保証できます。When disposing is true, the stream can also ensure data is flushed to the underlying buffer, and access other finalizable objects. これは、ことがありますできません間ファイナライザーの順序がなくなったのため、ファイナライザーから呼び出されるとします。This may not be possible when called from a finalizer due a lack of ordering among finalizers.

ストリームがそのソースとの通信に、オペレーティング システム ハンドルを使用している場合は、サブクラスを使用することを検討してくださいSafeHandleこの目的のためです。If your stream is using an operating system handle to communicate with its source, consider using a subclass of SafeHandle for this purpose.

このメソッドは、パブリックDisposeメソッドとFinalizeメソッド。This method is called by the public Dispose method and the Finalize method. Dispose 保護された起動Disposeメソッドをdisposingパラメーターに設定trueします。Dispose invokes the protected Dispose method with the disposing parameter set to true. Finalize 呼び出すDisposedisposingに設定falseします。Finalize invokes Dispose with disposing set to false.

注意 (継承者)

派生クラスでオーバーライドしないでください、Close()メソッドが代わりに、すべての Stream のクリーンアップ ロジックを配置、Dispose(Boolean)メソッド。In derived classes, do not override the Close() method, instead, put all of the Stream cleanup logic in the Dispose(Boolean) method.

Dispose() は、他のオブジェクトから複数回呼び出すことができます。Dispose() can be called multiple times by other objects. Dispose(Boolean) をオーバーライドする場合は、以前に Dispose() を呼び出したときに破棄されたオブジェクトを参照しないように注意する必要があります。When overriding Dispose(Boolean), be careful not to reference objects that have been previously disposed of in an earlier call to Dispose(). 実装する方法についての詳細はDispose(Boolean)を参照してくださいDispose メソッドの実装します。For more information about how to implement Dispose(Boolean), see Implementing a Dispose Method.

詳細についてはDispose()Finalize()を参照してくださいアンマネージ リソースのクリーンアップします。For more information about Dispose() and Finalize(), see Cleaning Up Unmanaged Resources.

適用対象