std :: cout / std :: cerr seg fault

时间:2015-06-30 03:05:40

标签: c++ shared-libraries

#include <iostream>
#include <cstring>
#include <dlfcn.h>
#include <fcntl.h>
#include <X11/X.h>
#include <X11/Xlib.h>

void* Module = nullptr;
typedef int (*XNextEventPtr)(Display *display, XEvent *event_return);


XNextEventPtr XNextEventHook = nullptr;


extern "C" int XNextEvent(Display* display, XEvent* event_return)
{
    if (event_return)
    {
        event_return->xany.send_event = false;
    }

    if (XNextEventHook)
    {
        return XNextEventHook(display, event_return);
    }
    return 0;
}


void __attribute__((constructor)) initialize() //DLLMain.
{
    char Root[256] = {0};
    strcat(Root, "/usr/lib");
    #if defined(__x86_64__)
    strcat(Root, "/x86_64-linux-gnu");
    #else
    strcat(Root, "/i386-linux-gnu");
    #endif // defined
    strcat(Root, "/libX11.so");

    Module = dlopen(Root, RTLD_GLOBAL | RTLD_LAZY);
    std::cout<<"Loaded"<<std::flush;
    XNextEventHook = reinterpret_cast<XNextEventPtr>(dlsym(Module, "XNextEvent")); //some reason RTLD_NEXT didn't find it.
    if (XNextEventHook)
    {
        std::cout<<"Found XNextEvent"<<std::flush;
    }
}

void __attribute__((destructor)) deinitialize() //DLLMain.
{
    if (Module)
    {
        dlclose(Module);
        Module = nullptr;
    }
}

然后我这样做:

LD_PRELOAD="~/Desktop/MyHook.so"  /usr/lib64/firefox

它会崩溃。但是,我将std::coutstd::cerr替换为printfperror,它完美无缺!

是否有std::cout会导致应用崩溃的原因?

似乎当我使用用C ++编写的应用程序加载模块时,它加载正常。但是如果我用C编写的应用程序加载模块,它就会崩溃。

想法?

1 个答案:

答案 0 :(得分:5)

  

但是如果我用C语言编写的应用程序加载模块,它就会崩溃。

C应用程序没有代码来调用C ++库的初始化例程:std::cout之类的流将是未初始化的。

请参阅常见问题解答here,具体为:

  

•编译main()时必须使用C ++编译器(例如,用于静态初始化)