轉載https://blog.csdn.net/iEearth/article/details/49952047
還有一篇博客也可以看看https://blog.csdn.net/xp5xp6/article/details/52513428
https://www.cnblogs.com/openix/p/3521166.html
/etc/ld.so.conf詳解 :
https://www.cnblogs.com/chris-cp/p/3591306.html
LD_PRELOAD,是個環境變量,用於動態庫的加載,動態庫加載的優先級最高,一般情況下,其加載順序為LD_PRELOAD>LD_LIBRARY_PATH>/etc/ld.so.cache>/lib>/usr/lib。程序中我們經常要調用一些外部庫的函數,以malloc為例,如果我們有個自定義的malloc函數,把它編譯成動態庫后,通過LD_PRELOAD加載,當程序中調用malloc函數時,調用的其實是我們自定義的函數,下面以一個例子說明。
// test.c #include <stdio.h> #include <stdlib.h> int main() { int i = 0; for (; i < 5; ++i) { char *c = (char*)malloc(sizeof(char)); if (NULL == c) { printf("malloc fails\n"); } else { printf("malloc ok\n"); } } return 0; }
編譯運行,結果如下:
$gcc -o test test.c $./test malloc ok malloc ok malloc ok malloc ok malloc ok
可以看出,程序運行沒有問題,我們稍作修改,自定義malloc。
// preload.c #include <stdio.h> #include <stdlib.h> void* malloc(size_t size) { printf("%s size: %lu\n", __func__, size); return NULL; }
然后把自定義的malloc打包為動態庫。
$gcc -shared -fpic -o libpreload.so preload.c
接着使用LD_PRELOAD加載libpreload.so,看看情況如何:
$LD_PRELOAD=./libpreload.so ./test
malloc size: 1 malloc fails malloc size: 1 malloc fails malloc size: 1 malloc fails malloc size: 1 malloc fails malloc size: 1 malloc fails
看到了吧,5次malloc都失敗了,如果不知道是 LD_PRELOAD在作怪,那可能分析很長時間都找不出原因所在。這個 LD_PRELOAD就是把雙刃劍,用好了可以幫助我們,如果別有用心,那可能會有意外的驚喜。
--------------------- 作者:aidear_evo 來源:CSDN 原文:https://blog.csdn.net/iEearth/article/details/49952047?utm_source=copy 版權聲明:本文為博主原創文章,轉載請附上博文鏈接!