调整大小并返回输出 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 方法