共用方式為


CBaseInputPin.ReceiveCanBlock 方法

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

方法 ReceiveCanBlock 會判斷 IMemInputPin::Receive 方法的呼叫是否可能會封鎖。 這個方法會實作 IMemInputPin::ReceiveCanBlock 方法。

語法

HRESULT ReceiveCanBlock();

參數

這個方法沒有任何參數。

傳回值

傳回 HRESULT 值。 可能的值包括下表所列的值。

傳回碼 Description
S_FALSE
針腳不會在對 Receive的呼叫上封鎖。
S_OK
針腳可能會在呼叫 [接收] 時封鎖。

備註

如果保證不會封鎖對 Receive 方法的呼叫,則傳回S_FALSE。 否則,傳回S_OK或錯誤碼。 如果 Receive 方法在下游針腳上呼叫 Receive ,下游針腳可能會封鎖; ReceiveCanBlock 必須將該因素納入考慮。

上游篩選準則可以使用這個方法來判斷其執行緒策略。 如果 Receive 方法可能會封鎖,上游篩選準則可能會決定使用緩衝資料的背景工作執行緒。 如需此策略的實作,請參閱 COutputQueue 類別。

在基類中,當下列任一項成立時,這個方法會傳回S_OK:

  • 篩選準則沒有輸出針腳。
  • 連接到此篩選準則的輸入針腳會發出可能封鎖的訊號。
  • 連接到此篩選準則的輸入針腳不支援 IMemInputPin 介面。

規格需求

需求
標頭
Amfilter.h (包含 Streams.h)
程式庫
Strmbase.lib (零售組建) ;
Strmbasd.lib (偵錯組建)

另請參閱

CBaseInputPin 類別