ICLRSyncManager::GetRWLockOwnerNext 方法
获取当前读取器-编写器锁上被阻止的下一个 IHostTask 实例。
语法
HRESULT GetRWLockOwnerNext (
[in] SIZE_T Iterator,
[out] IHostTask *ppOwnerHostTask
);
参数
Iterator
[in] 通过调用 CreateRWLockOwnerIterator 创建的迭代器。
ppOwnerHostTask
[out] 指向锁上正在等待的下一个 IHostTask
的指针,如果没有正在等待的任务,则为 NULL。
返回值
HRESULT | 说明 |
---|---|
S_OK | 已成功返回 GetRWLockOwnerNext 。 |
HOST_E_CLRNOTAVAILABLE | 公共语言运行时 (CLR) 未加载到进程中,或 CLR 处于无法运行托管代码或无法成功处理调用的状态。 |
HOST_E_TIMEOUT | 调用超时。 |
HOST_E_NOT_OWNER | 调用方未持有锁。 |
HOST_E_ABANDONED | 阻塞的线程或纤程正在等待某一事件,而该事件已被取消。 |
E_FAIL | 发生未知的灾难性故障。 当方法返回 E_FAIL 时,进程中无法再使用 CLR。 后续调用承载方法会返回 HOST_E_CLRNOTAVAILABLE。 |
注解
如果 ppOwnerHostTask
设置为 NULL,则迭代已终止,主机应调用 DeleteRWLockOwnerIterator 方法。
备注
CLR 调用 ppOwnerHostTask
指向的 IHostTask
上的 AddRef
,以防止该任务在主机保存指针时退出。 主机必须调用 Release
,以便在完成后减小引用计数。
要求
平台:请参阅系统要求。
标头:MSCorEE.h
库:作为资源包含在 MSCorEE.dll 中
.NET Framework 版本:自 2.0 起可用