gdb在另一个进程的上下文中运行?

问题描述:

我只想了解gdb(或其他调试器)如何修改另一个进程的地址空间中的内存?gdb在另一个进程的上下文中运行?

我们有一个正在运行的进程,我们重视它

连接pid

从这里我们可以通过修改这是在“连接进程的地址空间的内存(变量)。这怎么可能。什么是停止任何其他进程(而不是调试器)在做同样的事情。操作系统是否提供特殊的doors,供调试器使用,以查看/修改不同进程的地址空间?

还是我得到这个错误。在attach之后,进程是否在调试器的上下文中运行?如果是的话,这种变化如何发生?如果发生这种情况,我可以认为这将是一个写在副本?如果是这样,调试器将与修改的数据有不同的内存。但是,一旦我们从gdb修改了一些内存并从进程中分离出来,进程将继续看到修改过的数据....这是否意味着gdb可以访问此正在运行的进程的地址特征?

任何指标要了解这一点,将不胜感激。我可以看看gdb的代码,但代码很大,不知道从哪里开始。

谢谢。

在Linux上,API是ptrace()。它需要某些特权,这些特权在手册页中有详细说明。

有关如何使用它的教程,请参阅Playing with ptrace