IHostSemaphore::ReleaseSemaphore 方法

为当前 IHostSemaphore 实例的计数增加指定数量。

语法

HRESULT ReleaseSemaphore (  
    [in]  LONG  lReleaseCount,  
    [out] LONG  *lpPreviousCount  
);  

参数

lReleaseCount
[in] 为当前 IHostSemaphore 实例计数增加的数量。 数量必须大于零。

lpPreviousCount
[out] 指向上一个计数的指针,如果调用方不需要上一个计数,则为 null。

返回值

HRESULT 说明
S_OK 已成功返回 ReleaseSemaphore
HOST_E_CLRNOTAVAILABLE 公共语言运行时 (CLR) 未加载到进程中,或 CLR 处于无法运行托管代码或无法成功处理调用的状态。
HOST_E_TIMEOUT 调用超时。
HOST_E_NOT_OWNER 调用方未持有锁。
HOST_E_ABANDONED 阻塞的线程或纤程正在等待某一事件,而该事件已被取消。
E_FAIL 发生未知的灾难性故障。 当方法返回 E_FAIL 时,进程中无法再使用 CLR。 后续调用承载方法会返回 HOST_E_CLRNOTAVAILABLE。

备注

CLR 通常调用 ReleaseSemaphore 来通知主机,它已使用资源完成,为 lReleaseCount 参数传递值 1。

要求

平台:请参阅系统要求

标头:MSCorEE.h

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

.NET Framework 版本:自 2.0 起可用

另请参阅