CoInitializeSecurity返回错误 0x80010119


错误 0x80010119为:RPC_E_TOO_LATE CoInitializeSecurity has already been called。说明 CoInitializeSecurity 已经被调用过,这不算是错误。


判断该函数执行是否成功的方法应为:

HRESULT hr;

hr = CoInitialzieSecurity();

if (SUCCEED(hr) || RPC_E_TOO_LATE == hr)
{

}


另外,MSDN中提到过,这个初始化有显式调用和隐式调用之分,有时被COM隐式调用过我们还浑然不知。

我遇到过的一个场景就是,程序中只有一个地方调用这个函数,但一直返回RPC_E_TOO_LATE。后来我把这个函数放在进程启动时很前面的地方调用,就会返回成功了。隐式调用相关的参数来自注册表,不一定是自己想要的。所以想要初始化COM安全机制的时候,最好尽早做,以免因为其它操作引发隐式调用。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值