IGlobalRSCAQueryProvider::GetOutputBuffer メソッド
新 BYTE
しい配列を作成します。
構文
virtual HRESULT GetOutputBuffer(
DWORD cbBuffer,
OUT BYTE** ppbBuffer
) = 0;
パラメーター
cbBuffer
[IN] DWORD
割り当てるバイト数を格納している 。
ppbBuffer
[OUT]新しいバッファーを BYTE
含む配列へのポインター。
戻り値
HRESULT
。 有効な値を次の表に示しますが、これ以外にもあります。
値 | 定義 |
---|---|
S_OK | 操作が成功したことを示します。 |
E_OUTOFMEMORY | ヒープ メモリが使い果たされたことを示します。 |
解説
GL_RSCA_QUERY イベントに登録する CGlobalModule 派生クラスは、CGlobalModule::OnGlobalRSCAQuery メソッドのパラメーターとして IGlobalRscaQueryProvidervirtual
ポインターを受け取ります。 その後、ポインターで メソッドを呼び出すことで、GetOutputBuffer
新しいBYTE
配列をIGlobalRSCAQueryProvider
取得できます。
戻り値は GetOutputBuffer
実装によって異なります。 ガイドラインとして次の情報を使用する必要がありますが、すべてのシナリオで正しくない場合があります。
実装者は、 という名前buffer
のメンバー変数としてプライベート BYTE
ポインターを宣言します。実装者はIGlobalRSCAQueryProvider
、構築時に NULL に初期化しますbuffer
。 が 呼び出されたときに GetOutputBuffer
が NULL でない場合buffer
は、 でbuffer
LocalFree 関数が呼び出されます。 LocalAlloc 関数は、ヒープ上のサイズcbBuffer
の新BYTE
しい配列に割り当てるためbuffer
に呼び出されます。 buffer
が S_OK を返す場合GetOutputBuffer
は、逆参照されたppbBuffer
パラメーターで が返されます。
大事な このメソッドは IIS 7 インフラストラクチャの一部であり、コードから直接使用するためのものではありません。
実装側の注意
IGlobalRSCAQueryProvider
実装者は、このデータを使用したメモリ管理を担当します。そのため、IGlobalRSCAQueryProvider
動的メモリ割り当てを使用する実装者は、不要になったときにポインターをBYTE
解放または呼び出すdelete
必要があります。
呼び出し元に関する注意事項
IGlobalRSCAQueryProvider
実装者は、このデータを使用したメモリ管理を担当します。したがって、クライアントは、 IGlobalRSCAQueryProvider
このデータが不要になった場合に、返された BYTE
ポインターで delete を解放または呼び出す必要があります。
要件
Type | 説明 |
---|---|
Client | - Windows Vista 上の IIS 7.0 - Windows 7 上の IIS 7.5 - Windows 8 の IIS 8.0 - Windows 10の IIS 10.0 |
サーバー | - Windows Server 2008 の IIS 7.0 - Windows Server 2008 R2 上の IIS 7.5 - Windows Server 2012 上の IIS 8.0 - Windows Server 2012 R2 上の IIS 8.5 - Windows Server 2016上の IIS 10.0 |
製品 | - IIS 7.0、IIS 7.5、IIS 8.0、IIS 8.5、IIS 10.0 - IIS Express 7.5、IIS Express 8.0、IIS Express 10.0 |
Header | Httpserv.h |
参照
IGlobalRSCAQueryProvider インターフェイス
IGlobalRSCAQueryProvider::ResizeOutputBuffer メソッド