调整大小并返回输出 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
使用动态内存分配的实现程序必须在不再需要指针时释放或调用delete
BYTE
指针。
对调用者的说明
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 方法