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 で定義されているエラー コードのいずれかを返します。
注釈
ドライバーは CreateWdfObject を 呼び出して、独自に使用する一般的な フレームワーク ベース オブジェクト を作成できます。 ドライバーは、コンテキスト メモリを関連付け、親オブジェクトを割り当て、 IObjectCleanup インターフェイスを登録できます。 その後、フレームワークは IObjectCleanup::OnCleanup メソッドを呼び出して、子オブジェクトをクリーンします。
pParentObject パラメーターに親オブジェクトが指定されていない場合、ドライバーは既定の親になります。 そのため、ドライバー オブジェクトが削除されると、フレームワークによって子オブジェクトがクリーンアップされます。
親オブジェクトが割り当てられている場合、親オブジェクトが削除されると子オブジェクトが削除されます。 つまり、子オブジェクトの有効期間は、親オブジェクトのスコープ内に設定されます。
ドライバーが親オブジェクトを削除する前に子オブジェクトをクリーンする必要がある場合、ドライバーは IWDFObject::D eleteWdfObject メソッドを呼び出すことができます。
要件
要件 | 値 |
---|---|
サポート終了 | UMDF 2.0 以降では使用できません。 |
対象プラットフォーム | デスクトップ |
最小 UMDF バージョン | 1.5 |
Header | wudfddi.h (Wudfddi.h を含む) |
[DLL] | WUDFx.dll |