鱼C论坛

 找回密码
 立即注册
查看: 1955|回复: 5

[已解决]求助!

[复制链接]
发表于 2022-9-12 16:26:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 gandixiwang 于 2022-9-12 16:28 编辑

这是小甲鱼的正确代码
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define INCREMENT 10
  4. #define INIT_SIZE INCREMENT

  5. int main(void)
  6. {
  7.         char ch;
  8.         char *num=NULL; // 存储整个数据的首地址
  9.         char *last=NULL; // 最近一次迭代的起始地址
  10.         int limit = 0; // 每次迭代的限制值
  11.         long times = 1; // 记录重新申请多少次内存
  12.        
  13.         num = (char *)malloc(INIT_SIZE);
  14.         if (num == NULL)
  15.         {
  16.                 exit(1);
  17.         }
  18.        
  19.         last = num;
  20.        
  21.         printf("请输入一个整数:");
  22.        
  23.         while ((ch=getchar()) != '\n')
  24.         {
  25.                 last[limit++] = ch;
  26.                 if (limit >= INCREMENT)
  27.                 {
  28.                         int offset = last - num;
  29.                         num = (char *)realloc(num, INIT_SIZE + INCREMENT * times++);
  30.                         last = num;
  31.                         last += offset;
  32.                         last += INCREMENT;
  33.                         limit = 0;
  34.                 }
  35.         }
  36.         last[limit] = '\0';
  37.        
  38.         printf("你输入的整数是:%s\n", num);
  39.        
  40.         return 0;
  41. }
复制代码


为什么当我执行这个程序的时候他可以正常执行
但是当我对它进行调试的时候
  1. while ((ch=getchar()) != '\n')
复制代码

如果断点在这行代码之前(第25行代码)
ch变量就读不出里面的字符了?(此时ch变量='\0')

但是如果我把断点设置在这行代码之后
ch就能读取出我输入的第一个字符,但是当它开始循环,循环到这行代码时,他就又不能读取getchar()里面的字符了
Ps:我并不知道当我调试程序的时候 getchar(); 是否读取到了标准输入流里的字符来赋值给ch变量。
最佳答案
2022-9-12 20:27:15
本帖最后由 hrpzcf 于 2022-9-12 20:29 编辑


那有可能是你的程序出问题了,我看 last[limit++] = ch;并不会改变last,但是后面int offset = last - num;计算他们的差值,得到的offset是0

这样试试?
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define INCREMENT 10
  4. #define INIT_SIZE INCREMENT

  5. int main(void) {
  6.     char ch;
  7.     char *num = NULL;   // 存储整个数据的首地址
  8.     char *last = NULL;  // 最近一次迭代的起始地址
  9.     long times = 1;     // 记录重新申请多少次内存
  10.     int offset;

  11.     num = (char *)malloc(INIT_SIZE);
  12.     if (num == NULL) {
  13.         exit(1);
  14.     }

  15.     last = num;

  16.     printf("请输入一个整数:");

  17.     while ((ch = getchar()) != '\n') {
  18.         *last++ = ch;
  19.         offset = last - num;
  20.         if (offset >= INCREMENT) {
  21.             num = (char *)realloc(num, INIT_SIZE + INCREMENT * times++);
  22.             last = num + offset;
  23.         }
  24.     }
  25.     *last = '\0';

  26.     printf("你输入的整数是:%s\n", num);

  27.     return 0;
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-9-12 17:52:17 | 显示全部楼层
断点设在 while ((ch=getchar()) != '\n'),那你要点击下一步,然后在控制台输入 字符并回车,才能看到 ch 读到的字符。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-12 18:28:29 | 显示全部楼层
hrpzcf 发表于 2022-9-12 17:52
断点设在 while ((ch=getchar()) != '\n'),那你要点击下一步,然后在控制台输入 字符并回车,才能看到 ch  ...

关键是我不理解他为什么运行时不报错,但是调试时报错
调试时:

运行时:
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-12 18:29:21 | 显示全部楼层
本帖最后由 gandixiwang 于 2022-9-12 18:33 编辑

调试时
无标题.png
运行时
无标题1.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-12 20:27:15 | 显示全部楼层    本楼为最佳答案   
本帖最后由 hrpzcf 于 2022-9-12 20:29 编辑


那有可能是你的程序出问题了,我看 last[limit++] = ch;并不会改变last,但是后面int offset = last - num;计算他们的差值,得到的offset是0

这样试试?
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define INCREMENT 10
  4. #define INIT_SIZE INCREMENT

  5. int main(void) {
  6.     char ch;
  7.     char *num = NULL;   // 存储整个数据的首地址
  8.     char *last = NULL;  // 最近一次迭代的起始地址
  9.     long times = 1;     // 记录重新申请多少次内存
  10.     int offset;

  11.     num = (char *)malloc(INIT_SIZE);
  12.     if (num == NULL) {
  13.         exit(1);
  14.     }

  15.     last = num;

  16.     printf("请输入一个整数:");

  17.     while ((ch = getchar()) != '\n') {
  18.         *last++ = ch;
  19.         offset = last - num;
  20.         if (offset >= INCREMENT) {
  21.             num = (char *)realloc(num, INIT_SIZE + INCREMENT * times++);
  22.             last = num + offset;
  23.         }
  24.     }
  25.     *last = '\0';

  26.     printf("你输入的整数是:%s\n", num);

  27.     return 0;
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-12 20:52:28 | 显示全部楼层
hrpzcf 发表于 2022-9-12 20:27
那有可能是你的程序出问题了,我看 last[limit++] = ch;并不会改变last,但是后面int offset = last -  ...

搞好了,是我的编译器版本问题,我用的1.1版,更新到1.2版再调试就不会报错了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-23 22:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表