方大侠 发表于 2019-3-26 14:37:03

为什么这样写会引起字符数组的越界访问??

在写转置数组的时候说,这样写会引起字符数组的越界,但结果是正确的并且没有报错。
#include <stdio.h>

int main()
{
      char *array = {"FishC", "Five", "Star", "Good", "Wow"};
      char *(*p) = &array;
      int i, j;

      for (i = 0; i < 5; i++)
      {
                for (j = 0; j < 5; j++)
                {
                        if ((*p) == '\0')
                        {
                              break;
                        }
                        printf("%c ", (*p));
                }
                printf("\n");
      }

      return 0;
}
为什么会越界访问呢?不是遇到"\0"就break出来了吗??

文中给出的正确写法
#include <stdio.h>
#include <string.h>

int main()
{
      char *array = {"FishC", "Five", "Star", "Good", "Wow"};
      char *(*p) = &array;
      int i, j;

      for (i = 0; i < 5; i++)
      {
                for (j = 0; j < 5; j++)
                {
                        if (i > strlen((*p)) - 1)
                        {
                              break;
                        }
                        printf("%c ", (*p));
                }
                printf("\n");
      }

      return 0;
}

82457097 发表于 2019-3-26 14:37:04

本帖最后由 82457097 于 2019-3-26 15:27 编辑

确定能够正确打印转置后的数组?
i不和p的长度比较 就算你加了判断 不会越界打印 但是也得不到正确的结果啊 i=4的时候 j循环到1 就打印的\0 后面的就不打印了 而巧合是 后面的字符串都小于5位 不打印对结果也没有影响 打印正确 是巧合而已
而且没产生越界也是巧合 如果第一个字符串和最后一个字符串调换一下位置 程序直接就崩溃了

shake_a_tree@16 发表于 2019-3-26 15:17:22

在遇到\0的时候,你要访问这个\0才知道它到底是不是\0,而你一旦去访问它,就越界了

虽然printf("%c ", (*p));不会越界,但是if ((*p) == '\0')这个语句会越界

方大侠 发表于 2019-3-26 15:42:25

shake_a_tree@16 发表于 2019-3-26 15:17
在遇到\0的时候,你要访问这个\0才知道它到底是不是\0,而你一旦去访问它,就越界了

虽然printf("%c ",...

char *p = “SSS “;相当于
1.申请了空间,存放了字符串
2. 在字符串尾加上了'/0'
3.返回地址
/0不相当于也在数组内吗

Croper 发表于 2019-3-26 19:33:51

本帖最后由 Croper 于 2019-3-26 19:37 编辑

方大侠 发表于 2019-3-26 15:42
char *p = “SSS “;相当于
1.申请了空间,存放了字符串
2. 在字符串尾加上了'/0'


这样你只是针对这个特定数据而言,如果是这组呢?
char *array = {"FishC", "Wow", "Sta", "God", "Fif"};
那么p='C';
p就直接越界了

如果是这组呢?
char *array = {"a", "bb", "ccc", "dddd", "eeeee"};
你的函数能正确转置么
页: [1]
查看完整版本: 为什么这样写会引起字符数组的越界访问??