c高级编程4 LD_DEBUG
[root@monitor ~]# LD_DEBUG=help ls
Valid options for the LD_DEBUG environment variable are: libs display library search paths
reloc display relocation processing
files display progress for input file
symbols display symbol table processing
bindings display information about symbol binding
versions display version dependencies
all all previous options combined
statistics display relocation statistics
unused determined unused DSOs
help display this help message and exit To direct the debugging output into a file instead of standard output
a filename can be specified using the LD_DEBUG_OUTPUT environment variable.
[root@monitor ~]# LD_DEBUG=bindings /root/test
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_res' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_file_close' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `rpc_createerr' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__key_gendes_LOCAL' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__ctype32_tolower' [GLIBC_2.2]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `loc1' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `svc_pollfd' [GLIBC_2.2]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_funlockfile' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__malloc_initialize_hook' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `argp_program_version' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__tzname' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__after_morecore_hook' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__progname' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `obstack_exit_failure' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__check_rhosts_file' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `program_invocation_short_name' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_stdout_' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `optopt' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `malloc' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_environ' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_stderr_' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__key_encryptsession_pk_LOCAL' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__ctype_tolower' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__malloc_hook' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /root/test []: normal symbol `_IO_stdin_used'
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__progname_full' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `obstack_alloc_failed_handler' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__fpu_control' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `mallwatch' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `loc2' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__realloc_hook' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/ld-linux.so. []: normal symbol `__libc_stack_end' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `program_invocation_name' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `argp_program_version_hook' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__curbrk' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `stdout' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `svc_max_pollfd' [GLIBC_2.2]
: binding file /lib/libc.so. [] to /lib/ld-linux.so. []: normal symbol `_rtld_global_ro' [GLIBC_PRIVATE]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_nl_domain_bindings' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `stderr' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__ctype32_b' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/ld-linux.so. []: normal symbol `__libc_enable_secure' [GLIBC_PRIVATE]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_res_hconf' [GLIBC_2.2]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `argp_program_bug_address' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `h_errlist' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `optind' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/ld-linux.so. []: normal symbol `_dl_argv' [GLIBC_PRIVATE]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `svc_fdset' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_stdin_' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `re_syntax_options' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__rcmd_errstr' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__daylight' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `error_print_progname' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__ctype32_toupper' [GLIBC_2.2]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__ctype_b' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__ctype_toupper' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__morecore' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `getdate_err' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_nl_msg_cat_cntr' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `stdin' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__environ' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `svcauthdes_stats' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__memalign_hook' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__free_hook' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `error_message_count' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `free' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/ld-linux.so. []: normal symbol `_rtld_global' [GLIBC_PRIVATE]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__timezone' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `__key_decryptsession_pk_LOCAL' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `error_one_per_line' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `opterr' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `optarg' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `argp_err_exit_status' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_2_1_stdin_' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_2_1_stdout_' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_IO_2_1_stderr_' [GLIBC_2.1]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `calloc' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `realloc' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `malloc' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/ld-linux.so. []: normal symbol `___tls_get_addr' [GLIBC_2.3]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `memalign' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `free' [GLIBC_2.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `_Unwind_Find_FDE' [GCC_3.0]
: binding file /lib/libc.so. [] to /lib/libc.so. []: normal symbol `memmem' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/ld-linux.so. []: normal symbol `_r_debug' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/libc.so. []: normal symbol `free' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/libc.so. []: normal symbol `__libc_memalign' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/libc.so. []: normal symbol `malloc' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/libc.so. []: normal symbol `calloc' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/libc.so. []: normal symbol `realloc' [GLIBC_2.0]
: binding file /lib/ld-linux.so. [] to /lib/ld-linux.so. []: normal symbol `___tls_get_addr' [GLIBC_2.3]
: binding file /lib/ld-linux.so. [] to /lib/libc.so. []: normal symbol `free' [GLIBC_2.0]
:
: calling init: /lib/libc.so.
:
: binding file /root/test [] to /lib/libc.so. []: normal symbol `__libc_start_main' [GLIBC_2.0]
:
: initialize program: /root/test
:
:
: transferring control: /root/test
:
: binding file /root/test [] to /lib/libc.so. []: normal symbol `sbrk' [GLIBC_2.0]
: binding file /root/test [] to /lib/libc.so. []: normal symbol `brk' [GLIBC_2.0]
: binding file /root/test [] to /lib/libc.so. []: normal symbol `printf' [GLIBC_2.0] 0x9c22000
0x9c22004
(nil)
0x9c22004
0x9c22004
Segmentation fault
[root@monitor ~]# LD_DEBUG=libs /root/test //显示库如何加载的
: find library=libc.so. []; searching
: search cache=/etc/ld.so.cache
: trying file=/lib/libc.so.
:
:
: calling init: /lib/libc.so.
:
:
: initialize program: /root/test
:
:
: transferring control: /root/test
:
0x9a88000
0x9a88004
(nil)
0x9a88004
0x9a88004
Segmentation fault
c高级编程4 LD_DEBUG的更多相关文章
- 读《C#高级编程》第1章问题
读<C#高级编程>第1章 .Net机构体系笔记 网红的话:爸爸说我将来会是一个牛逼的程序员,因为我有一个梦,虽然脑壳笨但是做事情很能坚持. 本章主要是了解.Net的结构,都是一些概念,并没 ...
- MVC高级编程+C#高级编程
本人今年的目标是学习MVC高级编程和C#高级编程,把自己的基础打的扎实,本文中值是一个开到,定期会在上面记录学习的技术点和心得就,加油吧!!!!!
- 《C#高级编程》读书笔记
<C#高级编程>读书笔记 C#类型的取值范围 名称 CTS类型 说明 范围 sbyte System.SByte 8位有符号的整数 -128~127(−27−27~27−127−1) sh ...
- jquery插件开发继承了jQuery高级编程思路
要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈 ...
- jQuery高级编程
jquery高级编程1.jquery入门2.Javascript基础3.jQuery核心技术 3.1 jQuery脚本的结构 3.2 非侵扰事JavaScript 3.3 jQuery框架的结构 3. ...
- (十三) [终篇] 一起学 Unix 环境高级编程 (APUE) 之 网络 IPC:套接字
. . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...
- multiple definition of `err_sys' 《UNIX环境高级编程》
本文地址:http://www.cnblogs.com/yhLinux/p/4079930.html 问题描述: [点击此处直接看解决方案] 在练习<UNIX环境高级编程>APUE程序清单 ...
- Shell高级编程视频教程-跟着老男孩一步步学习Shell高级编程实战视频教程
Shell高级编程视频教程-跟着老男孩一步步学习Shell高级编程实战视频教程 教程简介: 本教程共71节,主要介绍了shell的相关知识教程,如shell编程需要的基础知识储备.shell脚本概念介 ...
- unix环境高级编程基础知识之第二篇(3)
看了unix环境高级编程第三章,把代码也都自己敲了一遍,另主要讲解了一些IO函数,read/write/fseek/fcntl:这里主要是c函数,比较容易,看多了就熟悉了.对fcntl函数讲解比较到位 ...
随机推荐
- Delphi 使用串口模拟工具进行串口程序开发调试
版权声明:本文为博主原创文章,如需转载请注明出处及作者. 本文由小李专栏原创,转载需注明出处:[http://blog.csdn.net/softwave/article/details/8907 ...
- MFC ListControl用法
http://blog.csdn.net/lovton/article/details/6527208 1.建立一个对象m_LogList 步骤:在对话listcontrol控件右键点击添加变量-&g ...
- <转>Python 多线程的单cpu与cpu上的多线程的区别
你对Python 多线程有所了解的话.那么你对python 多线程在单cpu意义上的多线程与多cpu上的多线程有着本质的区别,如果你对Python 多线程的相关知识想有更多的了解,你就可以浏览我们的文 ...
- 在/proc文件系统中增加一个目录hello,并在这个目录中增加一个文件world,文件的内容为hello world
一.题目 编写一个内核模块,在/proc文件系统中增加一个目录hello,并在这个目录中增加一个文件world,文件的内容为hello world.内核版本要求2.6.18 二.实验环境 物理主机:w ...
- Emmet:HTML/CSS代码快速编写神器(转)
Emmet的前身是大名鼎鼎的Zen coding,如果你从事Web前端开发的话,对该插件一定不会陌生.它使用仿CSS选择器的语法来生成代码,大大提高了HTML/CSS代码编写的速度,比如下面的演示: ...
- Intellij IDEA Maven创建web项目
Intellij IDEA在创建java webapp的时候没有那么人性化,新手使用会处处碰壁.特此记录! 一.File--New--project 二.Next--输入GroupId.Artifac ...
- 《Java数据结构与算法》笔记-CH3简单排序
class ArrayBub { private long[] arr; private int nElement; public ArrayBub(int size) { arr = new lon ...
- 第二百七十一天 how can I 坚持
每天的内容应该是这个样子,做了什么,收获了什么,有哪些东西感动了你. 就像昨天看了个电影<解救吾先生>,看完没点感觉或感受是不可能的,刘德华扮演的吾先生最终获救,不仅仅是靠运气,多少还是因 ...
- 当心回车符破坏你的JSON数据
今天发现系统中一个地方获取JSON数据时,时而失败,时而成功,最后发现是回车符搞的鬼. 当你的JSON中有回车符时,会致使你的JSON出现格式错误:解决办法是在保存数据,或整理数据向客户端输出时将回车 ...
- DllImport属性详解
API函数是构筑Windows的基石, 是Windows编程的必备利器.每一种Windows应用程序开发工具都提供间接或者直接的方式调用Win32API,C#也不例外.使用Win32API的一个好处就 ...