在与某些库链接时无法捕获异常
Cannot catch exceptions when linking with certain libraries
当与某个静态库链接时,我无法捕获可执行文件中的异常。我得到terminate called after throwing an instance of 'int'
, terminate called recursively
。
该库包含用gcc编译的C和汇编源代码,以及用g++编译的c++源代码。我猜这种混合物是问题的一部分。
谁能告诉我到底是什么问题?如果我能提供更多的信息来解释,请告诉我。谢谢。下面是一个简单的示例程序,当我链接到库时,它无法捕获异常。注意,我没有调用库中的任何函数。仅仅是链接库的行为就会导致此操作失败。
baz.cpp:
#include <iostream>
using namespace std;
int main(int argc, char** argv)
{
try {
throw 7;
} catch (int ex) {
cout << "int: " << ex << endl;
} catch (...) {
cout << "..." << endl;
}
}
编译/链接:
g++ -o baz -ggdb baz.cpp -lxxx
可选编译(模仿库中c++源代码的编译方式):
g++ -c -falign-functions=16 -D_REENTRANT -mtune=opteron -g -O2 -fPIC -Wall -Werror -Wpointer-arith -Wreturn-type -Wswitch -Wunused -Wundef -Wno-uninitialized -Wno-format -Wno-non-virtual-dtor -Wno-sign-compare -Wwrite-strings -DTRACE_SIMPLE -Wno-strict-aliasing -g -rdynamic -D_XOPEN_SOURCE=600 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64 -DXYZ_LITTLE_ENDIAN=1 -DXYZ_BIG_ENDIAN=0 -DXYZ=1 -DUMEM_TRACE=0 -DUSE_SYS_FLOAT -DINTEL_IPP_INLINE_MEMCHR=0 -DACCEL_TEST=1 -DXYZ -DUSE_XYZ_LIB -DACCEL_TEST=1 -o baz.o baz.cpp
创建的静态库是ar r
+ ranlib
。
terminate called after throwing an instance of 'int'
terminate called recursively
Aborted (core dumped)
核心回溯:#0 0x0000003ad4032625 in raise () from /lib64/libc.so.6
#1 0x0000003ad4033e05 in abort () from /lib64/libc.so.6
#2 0x0000003ad80be991 in __gnu_cxx::__verbose_terminate_handler() () from /usr/lib64/libstdc++.so.6
#3 0x0000003ad80bcbd6 in ?? () from /usr/lib64/libstdc++.so.6
#4 0x0000003ad80bcc03 in std::terminate() () from /usr/lib64/libstdc++.so.6
#5 0x0000003ad80bcc86 in __cxa_rethrow () from /usr/lib64/libstdc++.so.6
#6 0x0000003ad80bea32 in __gnu_cxx::__verbose_terminate_handler() () from /usr/lib64/libstdc++.so.6
#7 0x0000003ad80bcbd6 in ?? () from /usr/lib64/libstdc++.so.6
#8 0x0000003ad80bcc03 in std::terminate() () from /usr/lib64/libstdc++.so.6
#9 0x0000003ad80bcd22 in __cxa_throw () from /usr/lib64/libstdc++.so.6
#10 0x0000000000400a9b in main (argc=1, argv=0x7fffffff3888) at baz.cpp:8
GCC版本:
gcc -v
Using built-in specs.
Target: x86_64-redhat-linux
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-languages=c,c++,objc,obj-c++,java,fortran,ada --enable-java-awt=gtk --disable-dssi --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-1.5.0.0/jre --enable-libgcj-multifile --enable-java-maintainer-mode --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --disable-libjava-multilib --with-ppl --with-cloog --with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux
Thread model: posix
gcc version 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC)
谢谢大家。问题原来是库中存在一个C文件,其中包含诸如c++语言/库实现函数的声明/定义。我不确定为什么包含这个文件,因为删除它并重新编译库并没有引起任何问题(至少还没有…)。当链接到重新编译的库时,示例程序能够捕获异常。
如果有人想发表为什么这些声明/定义的存在导致异常没有被捕获,请随意,我可能会接受你的回答。我将尝试找出为什么包含这个文件开始。如有任何建议,不胜感激。
文件内容如下:
int __gxx_personality_v0(void);
int __gxx_personality_v0(void)
{
return 1;
}
void __cxa_pure_virtual(void);
void __cxa_pure_virtual(void)
{
}
void _ZTVN10__cxxabiv117__class_type_infoE(void);
void _ZTVN10__cxxabiv120__si_class_type_infoE(void);
void _ZTVN10__cxxabiv121__vmi_class_type_infoE(void);
void _ZTVN10__cxxabiv117__class_type_infoE(void) {}
void _ZTVN10__cxxabiv120__si_class_type_infoE(void) {}
void _ZTVN10__cxxabiv121__vmi_class_type_infoE(void) {}
相关文章:
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- CMake-按正确顺序将项目与C运行时对象文件链接
- 使用 Vivek 的 Vcam / 捕获源过滤器构建/链接错误
- C++ 使用生成文件捕获框架'multiple definition'链接器错误
- 链接列表正在抛出异常,而不是打印第一个节点
- 每次捕获测试框架较长的链接时间
- PCL 和 CMake 的问题:链接时未定义统计异常值删除
- 为什么混合 -fexceptions 和 -fno 异常没有链接器警告
- 在 C 库中链接后,C++ 中的异常捕获不再起作用
- C 错误:0x00934ABB(链接列表,地址簿)的未手动异常
- 链接列表导致异常,但不确定原因
- log4cxx构建并编译,但运行时会出现不满足链接异常
- 使用 Visual Studio 2012 的静态链接 msvcrt 中的异常
- 异常C++链接器错误 - 'Defined in discarded section'
- 使用不支持异常处理的代码(C++/LLVM)进行链接
- 使用JNA从java中的源对象(.so)文件内部调用C++函数时发生链接异常
- 捕获单元测试库链接错误
- 与LAPACK和BLAS的链接会导致c++异常无法处理
- GCC 4.5.2链接器在使用异常(c++)时遇到问题
- 在与某些库链接时无法捕获异常