共用方式為


IAsyncReader::SyncRead 方法 (strmif.h)

[與此頁面相關的功能 DirectShow 是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對 Windows 10 和 Windows 11 進行優化。 Microsoft 強烈建議新程式代碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式代碼盡可能重寫為使用新的 API。

方法 SyncRead 會執行同步讀取。 方法會封鎖直到要求完成為止。 檔案位置和緩衝區位址不需要對齊。 如果要求未對齊,方法會執行緩衝讀取作業。

語法

HRESULT SyncRead(
  [in]  LONGLONG llPosition,
  [in]  LONG     lLength,
  [out] BYTE     *pBuffer
);

參數

[in] llPosition

指定要開始讀取的位元組位移。 如果這個值超出檔案結尾,方法就會失敗。

[in] lLength

指定要讀取的位元元組數目。

[out] pBuffer

接收數據的緩衝區指標。

傳回值

傳回 HRESULT 值。 可能的值如下。

傳回碼 Description
S_FALSE
擷取的位元元數比要求少。 (可能到達檔案的結尾。)
S_OK
成功。

備註

即使篩選已停止,這個方法仍可運作。

規格需求

需求
最低支援的用戶端 Windows 2000 專業版 [僅限傳統型應用程式]
最低支援的伺服器 Windows 2000 Server [僅限傳統型應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

錯誤和成功碼

IAsyncReader 介面

IAsyncReader::SyncReadAligned