您好,欢迎访问三七文档
GDB基本使用方法GDB是用来调试用户态程序的一款工具,可以追踪程序运行轨迹,打出调用栈,寄存器内容,查看内存等等首先在编译时,我们必须要把调试信息加到可执行文件中。使用编译器(cc/gcc/g++)的-g参数可以做到这一点。如果没有-g,你将看不见程序的函数名、变量名,所代替的全是运行时的内存地址。启动GDB直接找到gdb的路径执行就ok,进入GDB后可以输入help命令查看帮助信息加载可执行文件启动gdbexecutable-filesetargs参数列表以上两步等同于gdb–argsexecutable-file参数列表run或者start都可以启动调试多用于调试启动阶段就异常的程序调试正在运行的程序以下三种形式都可以attach到正在运行的程序上调试ps-ef|grephttp:00:14/usr/sbin/lighttpdgdbattach24470gdb--pid24470gdb-p24470设置断点break--Setbreakpointatspecifiedlineorfunctionbfunc1breakfunc1设置在func1处bfile:line设置在文件的第几行处b*0x指令地址设置在具体的某条汇编指令处设置断点后,代码执行到func1处会被断住,方便我们查看当时的信息打印调用栈backtracebt如果你要查看栈下面层的详细信息frame栈中的层编号查看所有断点infobreak删除断点delete断点号如果不加断点号为删除全部断点禁用断点disable断点号启用断点enable断点号单步执行next或n单步进入step或s查看寄存器信息inforegistersir寄存器知识pc当前要执行的指令sp当前的栈地址ra当前调用返回地址,从当前函数栈返回后执行的第一条指令地址v0存储返回值v1当v0存储不下时使用a0,a1,a2,a3对应函数入参的第一,第二,第三,第四个参数,如果有更多参数,会压到当前栈中,调用的函数会去相应的位置取出来处理t9一般存放函数跳转地址打印信息print变量或地址查看内存信息x/32xw0x内存地址以x:16进制的形式显示32w(32个字,一个字=4B)的内存信息反汇编函数disassemble函数地址disassemble函数名线程断点在线程号为id的线程上设置断点breakfuncthreadid,如果你不指定thread则表示你的断点设在所有线程上面infothreads命令可以查看线程id号threadid可以切换到线程号为id的线程上,然后查看当前线程的寄存器及调用栈当你的程序被GDB停住时,所有的运行线程都会被停住调试core文件Core文件是程序非法执行后coredump后产生的文件。gdb–ccoreFilebinFile注意事项,gdb调试core文件时会占用大量内存,出现vtysh(终端)被系统杀死的情况,一般需要留35M以上的内存查看内存cat/proc/meminfoMemFree:74732kB调试web_mainnetstat-ple|grepweb_main955412705/web_main/var/usock/web_main.socket-0955712707/web_main/var/usock/web_main.socket-1一般挂住该进程,如果不准确,可以修改vi/etc/lighttpd/lighttpd.conf查找min到该处,把2改为1,重启httpd服务/etc/init.d/httpdrestartsocket=/var/usock/web_main.socket,bin-path=/var/local/web/func/web_main,check-local=disable,min-procs=2,max-procs=2,自定义输出查看当前进程状态ps-eTotid,pid,wchan:32,comm|grepsslvpn1259212592epoll_waitsslvpn1011012592futex_wait_queue_messlvpn1011112592futex_wait_queue_messlvpn
本文标题:GDB基本使用方法
链接地址:https://www.777doc.com/doc-2873618 .html