GDB:获取准确的内存地址,而不是<地址0x4越界>
GDB: getting exact memory address not < Address 0x4 out of bounds >
是否可以在初始化之前获取strs[i]的确切地址值,而不是"<地址0x4越界>"??如果可能的话,那么怎么做? 地址0x4越界>
(gdb) list
15 int main()
16 {
17 int j, i;
18 char *strs[4];
19
20 for (i = 0; i <= 3; i++)
21 {
22 strs[i] = new char [11];
23 }
24
25 for (i = 0; i <= 3; i++)
26 {
27 init(strs[i]);
28 }
29
30 for (j = 0; j <= 3; j++)
31 {
32 cout << strs[j] << endl;
33 }
34
35 return(0);
36
37 }
以下是 strs[i] 的值:
(gdb) p strs[i]
$4 = 0x4 < Address 0x4 out of bounds >
这不好:
char *strs[4];
for (i = 1; i <= 4; i++)
数组从 0 开始编制索引。 没有strs[4]
这样的元素,这就是你越界的原因。 地址毫无意义。
相关文章:
- 将数组的地址分配给变量并删除
- 空基优化子对象的地址
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 如何在c++程序中找到函数的地址
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 被解释为低级别const的const对象的地址
- 将地址分配给本地指针后,公共对象的变量将消失
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 内联程序集printf将整数解释为地址
- 为什么指针不写入类的地址?
- 如何在C++中获取该对象的类声明中对象的地址?
- 通过按地址访问变量
- EASTL矢量<向量<int>>连续的
- 当一个新对象被分配到它的地址时,对象是否必须被销毁
- 函数名是c中该函数的第一条指令的地址吗
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- ReadProcessMemory() 不适用于像 0x2840C6C68D8 这样的长地址
- CUDA:统一内存和指针地址的更改
- 当我们从/tp地址中添加/减去一个整数时会发生什么