如果在函数外部定义了onstream :: open()的段错误

时间:2019-03-05 14:32:52

标签: c++ linux fstream ofstream

我正在编写一个共享的库来通过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 

1 个答案:

答案 0 :(得分:2)

这是因为__attribute__((constructor))。在初始化全局变量ctor之前调用std::ofstream log_file函数,因此会导致段错误。