次の方法で共有


IWDFDriver::CreateWdfObject メソッド (wudfddi.h)

[警告: UMDF 2 は UMDF の最新バージョンであり、UMDF 1 よりも優先されます。 すべての新しい UMDF ドライバーは、UMDF 2 を使用して記述する必要があります。 UMDF 1 には新機能が追加されておらず、Windows 10 の新しいバージョンでは UMDF 1 のサポートが制限されています。 ユニバーサル Windows ドライバーでは、UMDF 2 を使用する必要があります。 詳細については、「UMDFの概要」を参照してください。

CreateWdfObject メソッドは、親 WDF オブジェクトからカスタム (またはユーザー) WDF オブジェクトを作成します。

構文

HRESULT CreateWdfObject(
  [in, optional] IUnknown   *pCallbackInterface,
  [in, optional] IWDFObject *pParentObject,
  [out]          IWDFObject **ppWdfObject
);

パラメーター

[in, optional] pCallbackInterface

IUnknown インターフェイスへのポインター。フレームワークは、新しく作成されたカスタム オブジェクトでドライバーがサブスクライブするオブジェクト関連のイベント コールバック関数を決定するために使用します。 このパラメーターは省略可能です。 ドライバーが通知 必要としない場合、ドライバーは NULL を渡すことができます。 ドライバーが有効なポインターを渡した場合、フレームワークは、IObjectCleanup インターフェイスの IUnknown インターフェイスで QueryInterface を呼び出します。 フレームワークがドライバーの IObjectCleanup インターフェイスを取得した場合、フレームワークは、その後、ドライバーの IObjectCleanup::OnCleanup メソッドを呼び出して、カスタム オブジェクトがクリーンアップされたことをドライバーに通知できます。

[in, optional] pParentObject

親 WDF オブジェクトの IWDFObject インターフェイスへのポインター。 null 場合、ドライバー オブジェクトは既定の親になります。

[out] ppWdfObject

新しく作成された WDF オブジェクトの IWDFObject インターフェイスへのポインターを受け取るバッファーへのポインター。

戻り値

CreateWdfObject 、操作が成功した場合にS_OKを返します。 それ以外の場合、このメソッドは Winerror.h で定義されているエラー コードの 1 つを返します。

備考

ドライバーは、CreateWdfObject 呼び出して、独自の用途に 一般的な フレームワークの基本オブジェクトを作成できます。 ドライバーは、コンテキスト メモリを関連付け、親オブジェクトを割り当て、IObjectCleanup インターフェイス 登録できます。 その後、フレームワークは IObjectCleanup::OnCleanup メソッドを呼び出して、子オブジェクトをクリーンアップします。

pParentObject パラメーターで親オブジェクトが指定されていない場合、ドライバーは既定の親になります。 そのため、ドライバー オブジェクトが削除されると、フレームワークは子オブジェクトをクリーンアップします。

親オブジェクトが割り当てられている場合、親オブジェクトが削除されると子オブジェクトが削除されます。 つまり、子オブジェクトの有効期間は、親オブジェクトのスコープ内に設定されます。

ドライバーが親オブジェクトを削除する前に子オブジェクトをクリーンアップする必要がある場合、ドライバーは、IWDFObject::D eleteWdfObject メソッドを呼び出すことができます。

必要条件

要件 価値
サポート終了 UMDF 2.0 以降では使用できません。
ターゲット プラットフォーム デスクトップ
UMDF の最小バージョン する 1.5
ヘッダー wudfddi.h (Wudfddi.h を含む)
DLL WUDFx.dll

関連項目

IObjectCleanup

IObjectCleanup::OnCleanup

IWDFDriver

IWDFObject

IWDFObject::D eleteWdfObject