我知道我们可以使用几个命令来访问和读取内存:例如,print,p,x ...
但是,如何在任何特定位置更改内存的内容(在GDB中调试时)?
Answers:
最简单的方法是设置程序变量(请参见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
还有更多。阅读手册。
set (str[6]) = 'c'
如果您有数组,也可以工作,例如char str[]
正如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字节内存
扩展此处提供的答案。
您可以set idx = 1
设置变量,但是不建议使用该语法,因为变量名称可能与set子命令冲突。例如,set w=1
这将是无效的。
这意味着您应该首选语法:set variable idx = 1
或set var idx = 1
。
最后但并非最不重要的一点是,您可以只使用可信赖的旧打印命令,因为它会计算表达式。唯一的区别是他还打印了表达式的结果。
(gdb) p idx = 1
$1 = 1
您可以在此处阅读有关gdb的更多信息。