写在前面
学习过Linux编程的同学都或多或少用过gdb来调试自己的程序,但是并没有很多的资源让我们学习有关调试器的东西。希望通过这篇文章,你可以了解基本的调试原理,更重要的是可以写出一个自己的简易调试工具。更有趣的是,你可以了解如何修改内存,来“愚弄”你的系统。
代码环境
系统:Ubuntu 16.04lts
语言:C++14
必要的库:readline
启动debug
在进行调试前,首先要执行我们的debug程序。因此,可以将程序设计为首先debug程序启动,然后将要debug的程序以参数的方式传入,然后debug程序fork子进程来执行。
int main(int argc, char* argv[]) {
if (argc < 2) {
std::cerr << "请输入要debug的程序";
return -1;
}
auto prog = argv[1];
int pid = fork(); //创建子进程
if (pid == 0) {
//子进程执行要debug的程序
}
else if (pid >= 1) {
//父进程执行debug程序
}
}
ptrace()函数
Linux中的ptrace()函数给我们监控子进程提供了一种很简洁、优雅的手段。它可以让我们观察、控制子进程的内存,signal等等。但是,由于要实现的功能非常多,ptrace()的参数也比较复杂。它的声明是这样的:
long ptrace(enum __ptrace_request request, pid_t pid,
void<