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) 尚未加载到进程中或者处于无法运行托管代码或成功处理调用的状态。

HOST_E_TIMEOUT

调用超时。

HOST_E_NOT_OWNER

调用方不拥有锁。

HOST_E_ABANDONED

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

E_FAIL

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

备注

如果 ppOwnerHostTask 设置为 Null,则迭代已终止,并且宿主应调用 DeleteRWLockOwnerIterator 方法。

注意注意

CLR 在 IHostTask 上调用 ppOwnerHostTask 指向的 AddRef 以防止宿主保存该指针时退出此任务。宿主必须在其结束时调用 Release 以减少引用数。

要求

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

**头文件:**MSCorEE.h

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

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

请参见

参考

ICLRSyncManager 接口

IHostSyncManager 接口