我正在编写一个共享的库来通过LD_PRELOAD测试某些事情,我想将日志写入文件。
以下代码有效:
void ctor() __attribute__((constructor));
void dtor() __attribute__((destructor));
void ctor() {
std::ofstream log_file;
log_file.open("/home/tristan/Test.log");
log_file << "Log Stuff..." << std::endl;
log_file.close();
}
这会导致段错误:
void ctor() __attribute__((constructor));
void dtor() __attribute__((destructor));
std::ofstream log_file;
void ctor() {
log_file.open("/home/tristan/Test.log");
log_file << "Log Stuff..." << std::endl;
log_file.close();
}
那是为什么?也许与构造函数属性有关?
我的GCC标志如下:
gcc -fPIC -m64 -shared -lstdc++ -o Test.so *.cpp
答案 0 :(得分:2)
这是因为__attribute__((constructor))
。在初始化全局变量ctor
之前调用std::ofstream log_file
函数,因此会导致段错误。