在c++中,fscanf如何分配内存地址
In C++, how does fscanf allocate memory address?
我是c++的新手,一直在试图弄清楚fscanf是如何为堆栈分配内存的。我写了一段代码,从一个简单的文件中读取,并将行值分配给一个数组。然后,我尝试打印出数组中每个元素的地址。
values = (double *)calloc(rows*columns, sizeof(double));
for (i = 0; i < rows; i++){
for (j = 0; j < columns; j++){
fscanf(input, "%s", buffer);
values[i*columns + j] = atof(buffer);
}
}
v = values;
for (i = 0; i < rows; i++){
for (j = 0; j < columns; j++){
printf("at [%d, %d] value %gn", i, j, values[i*columns + j]);
printf(" address is 0x%x also 0x%xn", &values[i*columns + j],
values + i*columns + j);
printf("*v is = %g and v = 0x%x nn", *v, v);
++v; /* increment v by 1*/
}
}
假设输入是一个.txt文件,包含一个1x3矩阵(向量),条目为1 2 4
。我得到以下结果:
at [0, 0] value 1
address is 0xb51600 also 0xb51600
*v is = 1 and v = 0xb51600
at [0, 1] value 2
address is 0xb51608 also 0xb51608
*v is = 2 and v = 0xb51608
at [0, 2] value 4
address is 0xb51610 also 0xb51610
*v is = 4 and v = 0xb51610
我不能理解的是地址从[0,0]跳到[0,1]跳了8,而它从[0,1]跳到[0,2]只跳了2。根据我从c++书籍中读到的,我认为地址应该按声明的数组类型的大小递增。有人能对这件事提供一些见解吗?
谢谢
我不能理解的是地址从[0,0]跳到[0,1]跳了8,而从[0,1]跳到[0,2]只跳了2。
不,那是另一个8。
记住,这是十六进制!
0x10 - 0x08 = 0x08
16 - 8 = 8
地址从[0,1]跳到[0,2]也因为HEX。
0xb51608 -> 0xb51609 -> 0xb5160A -> 0xb5160B -> 0xb5160C -> 0xb5160D -> 0xb5160E -> 0xb5160F -> 0xb51610
你可以通过Python快速使用HEX算法,例如:
$ python -c 'print 0xb51610 - 0xb51608'
8
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?