为什么这样写会引起字符数组的越界访问??
在写转置数组的时候说,这样写会引起字符数组的越界,但结果是正确的并且没有报错。#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 15:27 编辑
确定能够正确打印转置后的数组?
i不和p的长度比较 就算你加了判断 不会越界打印 但是也得不到正确的结果啊 i=4的时候 j循环到1 就打印的\0 后面的就不打印了 而巧合是 后面的字符串都小于5位 不打印对结果也没有影响 打印正确 是巧合而已
而且没产生越界也是巧合 如果第一个字符串和最后一个字符串调换一下位置 程序直接就崩溃了 在遇到\0的时候,你要访问这个\0才知道它到底是不是\0,而你一旦去访问它,就越界了
虽然printf("%c ", (*p));不会越界,但是if ((*p) == '\0')这个语句会越界 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: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]