如何使用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 = 1
或set var idx = 1
。
最后但并非最不重要的,你可以使用可靠的旧打印命令,因为它评估一个expression式。 唯一的区别是他也打印了expression式的结果。
(gdb) p idx = 1 $1 = 1
你可以在这里阅读关于gdb的更多信息。