IHostIoCompletionManager::GetHostOverlappedSize 方法

更新:2007 年 11 月

获取宿主要附加到 I/O 请求的任何自定义数据的大小。

HRESULT GetHostOverlappedSize (
    [out] DWORD *pcbSize
);

参数

  • pcbSize
    [out] 一个指针,指向除了 Win32 OVERLAPPED 对象的大小之外公共语言运行库 (CLR) 应分配的字节数。

返回值

HRESULT

说明

S_OK

成功返回 GetHostOverlappedSize

HOST_E_CLRNOTAVAILABLE

CLR 尚未加载到进程中或者处于无法运行托管代码或成功处理调用的状态。

HOST_E_TIMEOUT

调用超时。

HOST_E_NOT_OWNER

调用方不拥有锁。

HOST_E_ABANDONED

事件在被阻止的线程或纤程正在等待它时被取消。

E_FAIL

发生了未知的灾难性故障。如果某方法返回 E_FAIL,CLR 便无法再在进程中使用。对宿主方法的后续调用都将返回 HOST_E_CLRNOTAVAILABLE。

备注

对 Windows 平台 API 的所有异步 I/O 调用均采用 Win32 OVERLAPPED 对象,此对象能提供一些信息,如文件指针位置。要保持状态,进行异步 I/O 调用的应用程序通常向该结构添加自定义数据。GetHostOverlappedSizeIHostIoCompletionManager::InitializeHostOverlapped 使宿主能够包含这种自定义数据。

CLR 调用 GetHostOverlappedSize 方法以确定宿主要附加到 OVERLAPPED 对象的自定义数据的大小。

说明:

GetHostOverlappedSize 仅调用一次。宿主的自定义数据必须与每个 I/O 请求大小相同。

重要说明:

OVERLAPPED 对象自身的大小不包括在 pcbSize 的值中。

有关 OVERLAPPED 结构的更多信息,请参见 Windows 平台文档。

要求

**平台:**请参见 .NET Framework 系统要求

**头文件:**MSCorEE.idl

**库:**作为一项资源包含在 MSCorEE.dll 中

**.NET Framework 版本:**3.5 SP1、3.5、3.0 SP1、3.0、2.0 SP1、2.0

请参见

参考

ICLRIoCompletionManager

NativeOverlapped

IHostIoCompletionManager