用gcc 出现 Segmentation fault

  #include <stdio.h>
  #include <stdlib.h>
  #include <string.h>
  
  void stringSort(char* p[5])
  {
      int i, j;
      char temp[100];
  
      for(i = 0; i < 5; i++)
      {
          for (j = 0; j < 5-i; j++)
   /*           if (strcmp(p[j], p[j+1]))
              {
                 *temp = *p[j];
                  *p[j] = *p[j+1];
                  *p[j+1] = *temp;
              }
首先strcmp函数用错, 由于只有两个字符串相等时才返回0, 此时显然不能达到目的其次后面的三个交换语句用错, 这里只是将p[j]所在的单元内容赋值给temp所指向的单元,所以最终只有第一个字母进行了排序。再次感谢一楼的提醒
*/
    if (strcmp(p[j], p[j-1]) < 0)   
   {    
    strcpy(temp, p[j]);
    strcpy(p[j], p[j-1]);
    strcpy(p[j-1], temp);
   } 
}
      return;
  }


 int main()
  {
      char* p[5];
      char temp[100];
      int i;
  
      for (i = 0; i < 5; i++)
      {
          scanf("%s", temp);
          p[i] = (char*)malloc(sizeof(temp)+1); /*这里一定要分配内存,不然会出现segmentation falut*/  
        strcpy(p[i], temp);
      }
      stringSort(p);
      for (i = 0; i < 5; i++)
      {
          printf("%s\n", p[i]);
      }
  
      return 0;
  }

  

  

写的东西很简单, 就是用指针数组实现字符串的排序。 原先查了下这个Segmentation fault, 发现是没有分配内存。可现在内存已经分配了, 仍然出现这个错误, 而且还没找出这个错误在哪。。

转载于:https://www.cnblogs.com/NotGeek/archive/2011/08/08/2131032.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值