鱼C论坛

 找回密码
 立即注册
查看: 2935|回复: 4

[已解决]Program received signal SIGTRAP, Trace/breakpoint trap

[复制链接]
发表于 2023-1-2 12:05:48 | 显示全部楼层 |阅读模式

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

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

x
  1. #include<stdio.h>
  2. #include<stdlib.h>

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


  5. int main()
  6. {
  7.         char ch;
  8.         char *str;
  9.         char *last;
  10.         int limit = 0;
  11.         int times = 1;
  12.         int count = 0;
  13.        
  14.         str = (char *)malloc(sizeof(char) * INCREMENT);
  15.        
  16.         if(str == NULL)
  17.         {
  18.                 exit(1);
  19.         }
  20.        
  21.         last = str;
  22.        
  23.         printf("请输入一个字符串:");
  24.        
  25.         while((ch = getchar()) != '\n')
  26.         {
  27.                 last[limit++] = ch;
  28.                 if(limit >= INCREMENT)
  29.                 {
  30.                         str = (char *)realloc(str, INCREMENT * times + INCREMENT);
  31.                         last += 10;
  32.                 }
  33.                 count++;
  34.         }
  35.        
  36.         last[limit] = '\0';
  37.        
  38.         printf("反转后的结果是:");
  39.         for(int i = count;i >= 0;i--)
  40.         {
  41.                 printf("%c", str[i]);       
  42.         }
  43.        
  44.         return 0;
  45. }
复制代码

请问这个报错是什么意思呀,不太理解为什么,我输入I love FishC! 翻转后会出现乱码,有的时候就不会出现乱码
最佳答案
2023-1-2 13:39:04
  1. #include<stdio.h>
  2. #include<stdlib.h>

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


  5. int main()
  6. {
  7.         char ch;
  8.         char *str;
  9.         char *last;
  10.         int limit = 0;
  11.         int index = 0;
  12.         int times = 1;
  13.         int count = 0;
  14.         
  15.         //str = (char *)malloc(sizeof(char) * INCREMENT);
  16.         str = malloc(INCREMENT);    // 没有必要强制转换,没有必要乘以sizeof(char)
  17.                                     // 因为 sizeof(char) == 1
  18.         
  19.         if(str == NULL)
  20.         {
  21.                 exit(1);
  22.         }
  23.         
  24.         last = str;
  25.         limit = INCREMENT;
  26.         
  27.         printf("请输入一个字符串:");
  28.         
  29.         while((ch = getchar()) != '\n')
  30.         {
  31.                 last[index++] = ch;
  32.                 if(index >= limit)
  33.                 {
  34.                         //str = (char *)realloc(str, INCREMENT * times + INCREMENT);
  35.                         str = realloc(str, INCREMENT * times++ + INCREMENT);
  36.                         last = str;
  37.                         limit += INCREMENT;
  38.                 }
  39.                 count++;
  40.         }
  41.         
  42.         last[index] = '\0';
  43.         
  44.         printf("反转后的结果是:");
  45.         for(int i = count;i >= 0;i--)
  46.         {
  47.                 printf("%c", str[i]);
  48.         }
  49.         
  50.         free(str);      // 内存也不释放?谁教给你的?
  51.         printf("\n");   // 行也不换
  52.         
  53.         return 0;
  54. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-1-2 13:25:24 | 显示全部楼层
执行完33行之后,last还指向str吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-2 13:39:04 | 显示全部楼层    本楼为最佳答案   
  1. #include<stdio.h>
  2. #include<stdlib.h>

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


  5. int main()
  6. {
  7.         char ch;
  8.         char *str;
  9.         char *last;
  10.         int limit = 0;
  11.         int index = 0;
  12.         int times = 1;
  13.         int count = 0;
  14.         
  15.         //str = (char *)malloc(sizeof(char) * INCREMENT);
  16.         str = malloc(INCREMENT);    // 没有必要强制转换,没有必要乘以sizeof(char)
  17.                                     // 因为 sizeof(char) == 1
  18.         
  19.         if(str == NULL)
  20.         {
  21.                 exit(1);
  22.         }
  23.         
  24.         last = str;
  25.         limit = INCREMENT;
  26.         
  27.         printf("请输入一个字符串:");
  28.         
  29.         while((ch = getchar()) != '\n')
  30.         {
  31.                 last[index++] = ch;
  32.                 if(index >= limit)
  33.                 {
  34.                         //str = (char *)realloc(str, INCREMENT * times + INCREMENT);
  35.                         str = realloc(str, INCREMENT * times++ + INCREMENT);
  36.                         last = str;
  37.                         limit += INCREMENT;
  38.                 }
  39.                 count++;
  40.         }
  41.         
  42.         last[index] = '\0';
  43.         
  44.         printf("反转后的结果是:");
  45.         for(int i = count;i >= 0;i--)
  46.         {
  47.                 printf("%c", str[i]);
  48.         }
  49.         
  50.         free(str);      // 内存也不释放?谁教给你的?
  51.         printf("\n");   // 行也不换
  52.         
  53.         return 0;
  54. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-2 13:53:02 | 显示全部楼层
本帖最后由 人造人 于 2023-1-2 13:54 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define INCREMENT 10

  4. int main(void) {
  5.     char *str = NULL;
  6.     size_t index = 0;
  7.     size_t limit = 0;
  8.     printf("请输入一个字符串:");
  9.     while(1) {
  10.         int ch = getchar();
  11.         if(ch == '\n' || ch == EOF) break;
  12.         if(index >= limit) {
  13.             char *temp = realloc(str, limit += INCREMENT);
  14.             if(!temp) {free(str); return -1;}
  15.             str = temp;
  16.         }
  17.         str[index++] = ch;
  18.     }
  19.     printf("反转后的结果是:");
  20.     while(--index != -1) putchar(str[index]);
  21.     puts("");
  22.     free(str);
  23.     return 0;
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-1-2 17:27:56 | 显示全部楼层

谢谢哥,明白了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-23 00:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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