IGlobalRSCAQueryProvider::ResizeOutputBuffer 方法

调整大小并返回输出 BYTE 数组。

语法

virtual HRESULT ResizeOutputBuffer(  
   DWORD cbNewBuffer,  
   DWORD cbBytesToCopy,  
   IN OUT BYTE** ppbBuffer  
) = 0;  

parameters

cbNewBuffer
[IN]包含 DWORD 要分配的字节数的 。

cbBytesToCopy
[IN]一个 DWORD ,包含要从 ppbBuffer 中复制到新缓冲区的字节数。

ppbBuffer
[IN][OUT]指向 BYTE 包含新缓冲区的数组的指针。

返回值

HRESULT。 可能的值包括(但并不限于)下表中的项。

定义
S_OK 指示操作成功。
E_INVALIDARG 指示 cbBytesToCopy 大于 cbNewBuffer
E_OUTOFMEMORY 指示堆内存已用尽。

备注

注册GL_RSCA_QUERY事件的 CGlobalModule 派生类接收 IGlobalRscaQueryProvider 指针作为 CGlobalModule::OnGlobalRSCAQueryvirtual 方法上的参数。 然后,可以通过在指针上调用 ResizeOutputBuffer 方法来调整当前BYTE数组的大小IGlobalRSCAQueryProvider

返回 ResizeOutputBuffer 值取决于实现。 应将以下信息用作指南,但并非所有情况都正确:

实现 IGlobalRSCAQueryProvider 者将 private``BYTE 指针声明为名为 buffer的成员变量;实现器在构造时初始化 buffer 为 NULL。 cbBytesToCopy如果在调用 时ResizeOutputBuffer参数大于 cbNewBuffer 参数,ResizeOutputBuffer则 立即返回E_INVALIDARG。 否则,将调用 LocalAlloc 函数来创建一个大小 cbNewBuffer为 的新缓冲区,并将参数的内容 ppbBuffer (最大为) 的长度 cbBytesToCopy 复制到此新缓冲区中。 然后调用 LocalFree 函数以释放专用缓冲区,该缓冲区重新分配给新缓冲区。 private如果 ResizeOutputBuffer 返回 S_OK,则会在取消引用ppbBuffer参数中返回缓冲区。

重要 此方法是 IIS 7 基础结构的一部分,不应直接从代码中使用。

实现者须知

IGlobalRSCAQueryProvider实施者负责使用此数据进行内存管理;因此,IGlobalRSCAQueryProvider使用动态内存分配的实现程序必须在不再需要指针时释放或调用deleteBYTE指针。

对调用者的说明

IGlobalRSCAQueryProvider 实施者负责使用此数据进行内存管理;因此,当不再需要此数据时, IGlobalRSCAQueryProvider 客户端不得释放或调用 delete 返回 BYTE 的指针。

要求

类型 说明
客户端 - 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::GetOutputBuffer 方法