#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
它就会崩溃。但是,如果我用printf
或perror
代替std::cout
和std::cerr
,它可以完美地工作!
std::cout
会使应用程序崩溃是有原因的吗?
当我使用用C++编写的应用程序加载模块时,它似乎加载得很好。但是,如果我用C编写的应用程序加载模块,它就会崩溃。
想法?
但是,如果我用C编写的应用程序加载模块,它就会崩溃。
C应用程序将没有代码来调用C++库的初始化例程:像std::cout
这样的流将被取消初始化。
请参阅此处的常见问题解答,特别是:
•编译
main()
(例如,用于静态初始化(时,必须使用C++编译器