马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 gandixiwang 于 2022-9-12 16:28 编辑
这是小甲鱼的正确代码#include <stdio.h>
#include <stdlib.h>
#define INCREMENT 10
#define INIT_SIZE INCREMENT
int main(void)
{
char ch;
char *num=NULL; // 存储整个数据的首地址
char *last=NULL; // 最近一次迭代的起始地址
int limit = 0; // 每次迭代的限制值
long times = 1; // 记录重新申请多少次内存
num = (char *)malloc(INIT_SIZE);
if (num == NULL)
{
exit(1);
}
last = num;
printf("请输入一个整数:");
while ((ch=getchar()) != '\n')
{
last[limit++] = 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[limit] = '\0';
printf("你输入的整数是:%s\n", num);
return 0;
}
为什么当我执行这个程序的时候他可以正常执行
但是当我对它进行调试的时候while ((ch=getchar()) != '\n')
如果断点在这行代码之前(第25行代码)
ch变量就读不出里面的字符了?(此时ch变量='\0')
但是如果我把断点设置在这行代码之后
ch就能读取出我输入的第一个字符,但是当它开始循环,循环到这行代码时,他就又不能读取getchar()里面的字符了
Ps:我并不知道当我调试程序的时候 getchar(); 是否读取到了标准输入流里的字符来赋值给ch变量。
本帖最后由 hrpzcf 于 2022-9-12 20:29 编辑
那有可能是你的程序出问题了,我看 last[limit++] = ch;并不会改变last,但是后面int offset = last - num;计算他们的差值,得到的offset是0
这样试试? #include <stdio.h>
#include <stdlib.h>
#define INCREMENT 10
#define INIT_SIZE INCREMENT
int main(void) {
char ch;
char *num = NULL; // 存储整个数据的首地址
char *last = NULL; // 最近一次迭代的起始地址
long times = 1; // 记录重新申请多少次内存
int offset;
num = (char *)malloc(INIT_SIZE);
if (num == NULL) {
exit(1);
}
last = num;
printf("请输入一个整数:");
while ((ch = getchar()) != '\n') {
*last++ = ch;
offset = last - num;
if (offset >= INCREMENT) {
num = (char *)realloc(num, INIT_SIZE + INCREMENT * times++);
last = num + offset;
}
}
*last = '\0';
printf("你输入的整数是:%s\n", num);
return 0;
}
|