如何使用GDB修改内存内容?

我知道我们可以使用几个命令来访问和读取内存:例如,print,p,x …

但是我怎样才能在任何特定的位置更改内存的内容(在GDB中debugging的时候)呢?

最简单的是设置一个程序variables(见GDB:赋值 ):

(gdb) l 6 { 7 int i; 8 struct file *f, *ftmp; 9 (gdb) set variable i = 10 (gdb) pi $1 = 10 

或者,您可以通过地址更新任意(可写)位置:

 (gdb) set {int}0x83040 = 4 

还有更多。 阅读手册 。

正如尼古拉所说你可以使用gdb'set'命令来改变一个variables的值。

您也可以使用'set'命令来更改内存位置。 例如。 扩展尼古拉的例子:

 (gdb) l 6 { 7 int i; 8 struct file *f, *ftmp; 9 (gdb) set variable i = 10 (gdb) pi $1 = 10 (gdb) p &i $2 = (int *) 0xbfbb0000 (gdb) set *((int *) 0xbfbb0000) = 20 (gdb) pi $3 = 20 

这应该适用于任何有效的指针,并可以转换为任何适当的数据types。

扩大在这里提供的答案。

你可以set idx = 1来设置一个variables,但是不build议使用这种语法,因为variables名可能与一个设置的子命令冲突。 作为一个例子set w=1将无效。

这意味着您应该更喜欢语法: set variable idx = 1set var idx = 1

最后但并非最不重要的,你可以使用可靠的旧打印命令,因为它评估一个expression式。 唯一的区别是他也打印了expression式的结果。

 (gdb) p idx = 1 $1 = 1 

你可以在这里阅读关于gdb的更多信息。