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


Answers:


124

最简单的方法是设置程序变量(请参见GDB:Assignment):

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

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

(gdb) set {int}0x83040 = 4

还有更多。阅读手册


4
在访问任意内存位置之前,我是否需要设置程序变量?我不能立即运行第二个set命令吗?
Spidey 2012年

同样,set (str[6]) = 'c'如果您有数组,也可以工作,例如char str[]
xealits

29

正如Nikolai所说,您可以使用gdb'set'命令更改变量的值。

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

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

(gdb) p &i
$2 = (int *) 0xbfbb0000
(gdb) set *((int *) 0xbfbb0000) = 20
(gdb) p i
$3 = 20

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


set {char[100]}(0x00) = ""清除地址0x00上的100字节内存
davenpcj

16

扩展此处提供的答案。

您可以set idx = 1设置变量,但是不建议使用该语法,因为变量名称可能与set子命令冲突。例如,set w=1这将是无效的。

这意味着您应该首选语法:set variable idx = 1set var idx = 1

最后但并非最不重要的一点是,您可以只使用可信赖的旧打印命令,因为它会计算表达式。唯一的区别是他还打印了表达式的结果。

(gdb) p idx = 1
$1 = 1

您可以在此处阅读有关gdb的更多信息。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.