这是代码:
foo.h
extern "C" {
int sdq_init_connector(const SSchar* path);
}
foo.cxx
int sdq_init_connector(const SSchar* path)
{
Logger log(LOG_DEBUG, "sdq_init_connector");
/*
here goes some not so relevant code
*/
log.write("Here be dragons");
return 0;
}
还有 Logger 类,它在 foo 中使用,没什么有趣的,constructor(char * message)、destructor() 和 write(char * message)。
问题总结:
当我从测试设备调用 libfoo.so 时,它可以正常工作,但是在函数 sdq_init_connector 返回它之后从生产系统调用它时 SEGFAULTs backtrace 下面
#10 <signal handler called>
#11 0x583d7fee in Node::~Node() () from /opt/siebel/sba81/siebsrvr/mw/lib/libtl.so
#12 0x583de09a in Logger::~Logger() () from /opt/siebel/sba81/siebsrvr/mw/lib/libtl.so
#13 0x6c86e001 in sdq_init_connector () from /opt/siebel/sba81/siebsrvr/lib/libfoo.so
请注意 #12 有另一个具有相同对象名称的库。为什么我的内部对象需要来自某个外部库的析构函数?