s1e39:C语言的内存布局问题
#include <stdio.h>
#include <stdlib.h>
#define INCREMENT 10
#define INIT_SIZE INCREMENT
int main(void)
{
char ch;
char *num; // 存储整个数据的首地址
char *last; // 最近一次迭代的起始地址
int limit = 0; // 每次迭代的限制值
long times = 1; // 记录重新申请多少次内存
num = (char *)malloc(INIT_SIZE);
if (num == NULL)
{
exit(1);
}
last = num;
printf("请输入一个整数:");
while ((ch=getchar()) != '\n')
{
last = ch;
if (limit >= INCREMENT)
{
int offset = last - num;
num = (char *)realloc(num, INIT_SIZE + INCREMENT * times++);
last = num;
last += offset;
last += INCREMENT;
limit = 0;
}
}
last = '\0';
printf("你输入的整数是:%s\n", num);
return 0;
}
int offset = last - num;这个是什么意思 在21行的时候,两个指针指向了同一地址
在循环中,指针last位置会向后移动(第33和334行),指针num没有移动
这里offset就是获取这个last向后移动的字节数
页:
[1]