IMemAllocator::D ecommit メソッド (strmif.h)
[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayer、IMFMediaEngine、Audio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ API を使用する既存のコードを、可能であれば新しい API を使用するように書き換えるよう提案しています。]
メソッドは Decommit
バッファー メモリを解放します。
構文
HRESULT Decommit();
戻り値
成功した場合はS_OK、エラーの原因を示す HRESULT 値を返します。
注釈
IMemAllocator::GetBuffer メソッドで待機しているスレッドは、エラーを返します。 GetBuffer のそれ以降の呼び出しは、IMemAllocator::Commit メソッドが呼び出されるまで失敗します。
メソッドの Decommit
目的は、フィルターがアロケーターからそれ以上のサンプルを取得しないようにすることです。 サンプルの参照カウントを既に保持しているフィルターは影響を受けません。 ただし、フィルターによってサンプルが解放され、参照カウントが 0 になると、サンプルは使用できなくなります。
アロケーターは、参照カウントが 0 の任意のサンプルに属するメモリを解放できます。 したがって、メソッドは Decommit
、フィルターがアクセスを停止するという意味でメモリを "解放" します。 メモリが実際にヒープに戻るかどうかは、アロケーターの実装によって異なります。 一部のアロケーターは、独自のデストラクター メソッドまで待機します。 ただし、アロケーターは、自身を削除するときに、割り当てられたメモリを残してはなりません。 したがって、アロケーターのデストラクターは、そのすべてのサンプルが解放されるまで待機する必要があります。
要件
要件 | 値 |
---|---|
サポートされている最小のクライアント | Windows 2000 Professional [デスクトップ アプリのみ] |
サポートされている最小のサーバー | Windows 2000 Server [デスクトップ アプリのみ] |
対象プラットフォーム | Windows |
ヘッダー | strmif.h (Dshow.h を含む) |
Library | Strmiids.lib |