在编写c
代码时,我注意到当我更改与指针x指向的内存位置相关联的值时,它会导致指针y指向的数据值的更改。
当我再次检查时,我发现malloc
正在为2个不同的指针分配重叠的内存区域。为什么会发生这种情况?
我的代码中有很多动态分配的变量。那么是因为malloc
可以分配的最大内存量有限制吗?
以下是我的代码的输出。从输出中可以看出malloc
将重叠的内存区域分配给x和y。
size x:32 y:144 //total size allocated to x and y by malloc
//the memory locations allocated to each of the pointers
location x:0x7fb552c04d20 y:0x7fb552c04c70
location x:0x7fb552c04d24 y:0x7fb552c04c8c
location x:0x7fb552c04d28 y:0x7fb552c04ca8
location x:0x7fb552c04d2c y:0x7fb552c04cc4
location x:0x7fb552c04d30 y:0x7fb552c04ce0
location x:**0x7fb552c04d34** y:0x7fb552c04cfc
location x:0x7fb552c04d38 y:0x7fb552c04d18
location x:0x7fb552c04d3c y:**0x7fb552c04d34**
我用于分配内存的代码是
int *x = (int *)malloc((DG_SIZE+1)*sizeof(int));
int *y = (int *)malloc(4*(DG_SIZE+2)*sizeof(int));
printf("\n size x:%d y:%d\n", (DG_SIZE+1)*sizeof(int), 4*(DG_SIZE+2)*sizeof(int));
int a = 0;
for(a = 0; a <= DG_SIZE; a++){
printf("\n location x:%p y:%p\n",(x + a), (y + a*DG_SIZE + 0));
}
答案 0 :(得分:9)
y
块完全位于内存中的x
块之前。没有重叠。
但是,您的循环会将y
块末尾之外的地址打印到y
列。
具体做法是:
int *y = (int *)malloc(4*(DG_SIZE+2)*sizeof(int));
已分配36
个整数,因为DG_SIZE
为7
(基于您的输出)。
然后你将a
从0
循环到7
并输出(y + a*DG_SIZE + 0)
。当a == 6
时,这会给y + 42
提供超出所分配的36个整数的结尾。
我猜你的意思是输出y + a*4
,而不是y + a*DG_SIZE
。