2024-12-01 16:17:55
这种情况下,
在str[0]=a;下面追加一句
str[1]=‘\0’;语句,可以输出正确的R了吗?
你还需要把 s 的容量加大。
声明里的 char str[1]; 改为 char str[2];
字符串数组的容量永远要比字符串长度多1。并要保证字符串最后一个字符后面跟一个'\0'。
除非你的字符数组不作为字符串使用。就是不用 printf("%s",s),不用 strlen, strcpy...之类的函数。
谢谢你的回答,我略显明白,恕我愚笨,如果我把char str[2]; 定义的非常大比如char str[500];这样的话结果也不对了,是为什么?
不会不对的啊。只要你的 '\0' 是赋给 str[1]; 要注意,'\0' 必须跟在字符串最后一个字符的后面。你要是给 str[499] 赋值就会出错了。
#include <stdio.h>
#include <string.h>
int main()
{
char a,b,c;
char str[500];
a = 'R';
b = 'X';
c = 'Y';
str[0] = a;
str[1] = '\0';
printf("%s\n",str);
return 0;
}
2024-12-01 14:15:53
2024-12-01 04:32:15
这种情况下,
在str[0]=a;下面追加一句
str[1]=‘\0’;语句,可以输出正确的R了吗?
不能
char str[1]; 你这个数组只有一个元素 数组大小是1 str[0]
如果你去操作str[1] 这是越界了 是非常危险的
char str[2]; 这样定义数组 才有str[0] str[1] 两个元素
再加str[1]=‘\0’; 就对了
谢谢你的回答,我略显明白,恕我愚笨,如果我把char str[2]; 定义的非常大比如char str[500];这样的话结果也不对了,是为什么?
只要有 '\0'
无论你定义多大的数组
只要能够存放 R和 '\0'
str[0] str[1] str[2]......
R '\0' 后面随便存什么
那么就不会出错 printf("%s",str) 就是R
str[0] str[1] str[2]......
R R '\0'
printf("%s",str) 就是 RR
%s就是输出字符串
还不对你可以贴上代码 我看看
我觉得我明白问题出在哪里了,谢谢你的帮助。
问题出在了数组以‘\0’结束也已'\0'开始,是这样吧?
如果我把char str[500]="";就表示这个字符串里是空的赋值的时候自然会在'\0'后面设定赋值内容。
上面的代码里只是声明了500个长度的字符串是内存空间里的任意位置,内容自然也就随机了。
即使把我要赋值的末尾加上'\0',但是开始的地方也是在内存里随机的'\0'位置开始的。
可以这样理解吗?
我想你明白结尾了 但是还是没明白开头
数组名 是数组的首地址 是吧
str其实代表的是一个内存地址 数组从这个地方开始 大小为500个char
”上面的代码里只是声明了500个长度的字符串是内存空间里的任意位置“
这句话不对 他是以数组首地址开始的 连续的内存单元 确定了数组首地址 那么后面的地址单元也是确定的 只是里面的值 我们是不确定的
你想太多了 '\0' 只是字符串的结尾符 和数组开头结束都没关系
‘\0’只和字符串有关系