我最近在proggit上看到了它的引用,(到目前为止)它没有解释。
我怀疑可能就是这个原因,但我也不确定。
我最近在proggit上看到了它的引用,(到目前为止)它没有解释。
我怀疑可能就是这个原因,但我也不确定。
当前回答
如果将LD_PRELOAD设置为共享对象的路径,则该文件将在任何其他库(包括C运行时libc.so)之前加载。所以要用你特殊的malloc()实现运行ls,这样做:
$ LD_PRELOAD=/path/to/my/malloc.so /bin/ls
其他回答
导出mylib。env:
$ export LD_PRELOAD=/path/mylib.so
$ ./mybin
禁用:
$ unset LD_PRELOAD
下面是一篇关于预加载的详细博文:
https://blog.cryptomilk.org/2014/07/21/what-is-preloading/
LD_PRELOAD列出了包含覆盖标准集的函数的共享库,就像/etc/ld.so.一样预加载。它们是由加载器/lib/ld-linux.so实现的。如果你想覆盖一些选定的函数,你可以通过创建一个覆盖对象文件并设置LD_PRELOAD;该对象文件中的函数将只覆盖那些函数,而其他函数则保持原样。
有关共享库的更多信息,请访问 http://tldp.org/HOWTO/Program-Library-HOWTO/shared-libraries.html
如果将LD_PRELOAD设置为共享对象的路径,则该文件将在任何其他库(包括C运行时libc.so)之前加载。所以要用你特殊的malloc()实现运行ls,这样做:
$ LD_PRELOAD=/path/to/my/malloc.so /bin/ls
使用LD_PRELOAD路径,可以强制应用程序加载器加载所提供的共享对象,而不是默认提供的共享对象。
开发人员通过提供共享对象的不同版本来调试应用程序。
我们已经使用它来破解某些应用程序,通过使用准备好的共享对象覆盖现有函数。