次の方法で共有


IAMDevMemoryControl::WriteSync メソッド (strmif.h)

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayerIMFMediaEngine、および Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、従来の API を使用する既存のコードを、可能であれば新しい API を使用するように書き直すよう提案しています。]

メモIAMDevMemoryControl インターフェイスは非推奨です。
 
完了した書き込みと同期するために使用されます。 このメソッドは、特定のアロケーター領域に書き込まれるデータがメモリに完全に書き込まれたときに を返します。

構文

HRESULT WriteSync();

戻り値

HRESULT 値を返します。 次の値があります。

リターン コード 説明
E_FAIL
このメソッドでデータが書き込まれたことを確認せずにタイムアウトが発生しました。
S_OK
データがメモリに正常に書き込まれた。
VFW_E_NOT_COMMITTED
アロケーターが IMemAllocator::Commit メソッドを呼び出していません。

注釈

このメソッドは、割り当てられたメモリに対する以前のすべての書き込み操作が成功したことを保証します。 後続のメモリ書き込み操作では、 への別の呼び出しが WriteSync必要です。

このメソッドは実装に依存し、(必要に応じて) メモリ書き込み操作をメモリに同期するために使用されます。 オンボード メモリのドライバーは、実装を提供します。

IAMDevMemoryControl インターフェイスは、通常、周辺機器コンポーネント相互接続 (PCI) ブリッジを介してアクセスされるメモリ上にあります。 (PCI は、プロセッサと周辺機器の間の高速データ パスを提供するパーソナル コンピューター用のローカル バスです)。別のデバイスが PCI ブリッジの背後からそのメモリにアクセスする場合、PCI ブリッジの背後にあるメモリは、メモリ書き込み操作の完了後に同期する必要があります。 これは、メモリへのホスト アクセスが PCI ブリッジ FIFO (最初の出力) を介してバッファーされ、ブリッジが実際にデータを書き込む前に書き込みが完了したとホストが想定するためです。 ブリッジの背後にあるデバイス (SCSI コントローラーなど) による後続のアクションは、 IAMDevMemoryControl::WriteSync メソッドが呼び出されない場合、書き込みが完了する前にメモリを読み取る可能性があります。

要件

要件
対象プラットフォーム Windows
ヘッダー strmif.h (Dshow.h を含む)

こちらもご覧ください

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

IAMDevMemoryControl インターフェイス