求助!
本帖最后由 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 = 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;
}
为什么当我执行这个程序的时候他可以正常执行
但是当我对它进行调试的时候
while ((ch=getchar()) != '\n')
如果断点在这行代码之前(第25行代码)
ch变量就读不出里面的字符了?(此时ch变量='\0')
但是如果我把断点设置在这行代码之后
ch就能读取出我输入的第一个字符,但是当它开始循环,循环到这行代码时,他就又不能读取getchar()里面的字符了
Ps:我并不知道当我调试程序的时候 getchar(); 是否读取到了标准输入流里的字符来赋值给ch变量。 断点设在 while ((ch=getchar()) != '\n'),那你要点击下一步,然后在控制台输入 字符并回车,才能看到 ch 读到的字符。 hrpzcf 发表于 2022-9-12 17:52
断点设在 while ((ch=getchar()) != '\n'),那你要点击下一步,然后在控制台输入 字符并回车,才能看到 ch...
关键是我不理解他为什么运行时不报错,但是调试时报错
调试时:
运行时:
本帖最后由 gandixiwang 于 2022-9-12 18:33 编辑
调试时
运行时
本帖最后由 hrpzcf 于 2022-9-12 20:29 编辑
gandixiwang 发表于 2022-9-12 18:29
调试时
运行时
那有可能是你的程序出问题了,我看 last = 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;
} hrpzcf 发表于 2022-9-12 20:27
那有可能是你的程序出问题了,我看 last = ch;并不会改变last,但是后面int offset = last -...
搞好了,是我的编译器版本问题,我用的1.1版,更新到1.2版再调试就不会报错了{:5_109:}
页:
[1]