接口指针使用时:Unhandled exception ... Stack overflow

现象:
COM进程外组件有个方法CreateDog(IUnknown** ppUnk)),用于创建一个IDog接口,当要直接把spDog智能指针传给CreateDog方法,发现传递回来的接口是非空的,而且返回值也是S_OK,但是一量使用这个指针去调用他的方法(QI三函数没问题)就出弹出断言:Unhandled exception ... Stack overflow.

在多方帮助之下,终于发现了问题的根本:
因为是进程外的组件,只能传递IUnknown**接口指针,(A同学:这个我当然知道,要不然参数也不会是IUnknonw**了),可是为什么我把spDog传给函数做[out]参数呢?你可能想当然的认为从IUnknown强制转换成IDog这是多么“常用、方便”的手法!
问题就出在这!在进程内组件中,我们如果这样强制转换是没有问题的,因为进程内(确切的说应该是套间内)的参数传递没有列集操作,可是在进程间,传递出来的IUnknown已经和你在进程内得到的是另外一份,你又怎么可能奢求他还包含有IDog的vtable,所以正确的做法应该是你在外面得到IUnknown指针后再去QueryInterface一次IDog,这样得到的指针才是正确的。

总结:
在接口的使用上,最好不要从IUnknown强制转换到你想要的接口,而是采用标准做法:QueryInterface

哈哈。。我又犯了个错!  

你可能感兴趣的:(exception)