我有一个名为ftest的测试程序。它加载包含测试的.so文件并运行它在那里找到的测试。其中一个测试加载并运行.so,其中包含用于O / RM的Postgres数据库驱动程序。
当Postgres驱动程序抛出在该.so文件中定义的异常(或者它链接到的那个,但是ftest没有链接到)并且被测试框架捕获时,异常析构函数会触发段错误。
只要编译的异常位于动态加载的.so中(使用dload),就会发生此段错误。
这种东西在Windows中运行良好,具有相同的架构。我们并不想限制自己只使用来自核心库的异常 - 加载项应该可以自由创建自己的异常类并正常处理它们。
例外是std :: exception的子类。有时可以在库中定义异常(例如libpqxx),这意味着异常有时也不受我们的控制。
使用以下内容抛出异常:
throw exception_class( exception_arguments );
并使用以下方式捕获:
catch ( std::exception &e ) {
// handler code
}
是否需要一些特殊的编译器选项才能使其正常工作?我们是否需要切换到通过throw new exception_class( args )
抛出异常(我们真的不想这样做)?
答案 0 :(得分:6)
假设你使用gcc -
在构建调用dlload()的可执行文件时附加-Wl,-E。这将导出可执行文件中的所有类型信息符号,这应该允许RTTI(在捕获异常时)正常工作。
VC ++使用字符串比较来匹配typeinfo,导致更慢的dynamic_cast<>等,但较小的二进制文件。 g ++使用指针比较。
尝试使用在运行时加载的.so中实现的纯虚拟接口类时遇到了同样的问题。
网上还有一些与该主题有关的文章。
希望有所帮助, 海曼。