次の方法で共有


IMemAllocator::D ecommit メソッド (strmif.h)

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/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

こちらもご覧ください

エラーコードと成功コード

IMemAllocator インターフェイス