以下是我使用的类的摘录,它继承自 TAO 中的 PortableServer::ServantLocator 类。当调用 preinvoke() 的重写方法时,如果仆人为 NULL(在此实例之前已被销毁),我将 CORBA::OBJECT_NOT_EXIST() 异常抛出回来,如下所示
class Locator : public PortableServer::ServantLocator {
public:
PortableServer::Servant preinvoke(
const PortableServer::ObjectId& oid,
PortableServer::POA_ptr adapter,
const char * operation,
Cookie& cookie ) throw ()
{
.
.
.// retrieve servant
.
if (servant == NULL) {
//return NULL;
throw CORBA::OBJECT_NOT_EXIST ();
}
return servant;
}
};
但这会使用以下核心转储使进程崩溃
[1] __exdbg_notify_of_unexpected(0xfffffc7ffad91640, 0x1, 0xfffffc7ffb849200, 0xfffffc7ffce202e0, 0x18, 0x101010101010101), at 0xfffffc7ffce07f90
[2] __Crun::ex_chk_unexpected(0x0, 0x0, 0x0, 0x0, 0x0, 0x0), at 0xfffffc7ffce09234
[3] Locator::preinvoke(this = 0x7c77f0, oid = CLASS, adapter = 0xdcf538, operation = 0xfffffc7ffad92740 "nextData", cookie = (nil)), line 238 in "locator.cpp"
[4] TAO::Portable_Server::RequestProcessingStrategyServantLocator::locate_servant(0x0, 0x0, 0x0, 0x0, 0x0, 0x0), at 0xfffffc7ffd7521d2
为什么 TAO 库没有捕捉到我抛出的异常?我对此做了很多谷歌搜索,但找不到任何解决方案。我参考这里的例子抛出了这个异常。我还尝试返回 NULL,希望在 TAO 中的调用方函数 RequestProcessingStrategyServantLocator::locate_servant() 处检查 NULL 指针异常可以处理它。即使那样,我也会得到相同的核心转储。
我的另一个问题是,如果我已经销毁了仆人并删除了它的引用,为什么 TAO 会首先调用 preinvoke()。任何人都可以向我展示如何删除 this 引用的一个很好的例子,这样 preinvoke() 就不会被调用?
编辑
我正在使用 ACE TAO 6.0.7_x86
正如@Johnny Willemsen 的回复中所建议的那样,我在客户端代码中发现异常,即调用服务器操作的地方。但它没有在这里被抓住。代码仍然崩溃。
我的客户端代码如下所示
try
{
rs->getValue(tab.out());
}
catch (CORBA::OBJECT_NOT_EXIST& x)
{
cout << "OMG OMG ERROR: CORBA : " << x << endl;
}