c语言字符的问题,为啥这个程序结果输出是RRXY

为啥这个程序结果输出是RRXY
#include <stdio.h>
#include <string.h>

main()
{
char a,b,c;
char str[1];

a = 'R';
b = 'X';
c = 'Y';

str[0]=a;
printf("%s\n",str);

}
最新回答
人间有爱不孤独。

2024-12-01 16:17:55

char 数组存放字符串数组长度必须比字符串长度多1字节。最后一个字节为 '\0' 表示字符串结束。
你这里 str 只有1字节容量,存放了字符之后,没有字符串结束符。这样 printf 输出时会出错,会一直输出到随机碰到的 '\0' 字符才结束。除了第一个字节 R 之外,后面显示什么都有可能。这里显示 RRXY 应该是刚好 char str 在内存中的位置排在 a,b,c 之前,所以输出的时候实际是输出了 str[0]的内容接着输出了 a,b,c的内容。然后后面内存的数据是0,printf 就结束输出了。你把 char str[1] 改为 char str[2],再给 str[1] 赋值个0就正常了。
追问
这种情况下,
在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

这个是有一点不确定性的,
你用%s来输出一个字符串数组,要以‘\0’结束不然你的输出值不确定,至于你输出的是RRXY 这与你的编译器有关,与语言无关。
星空伪装的忧蓝

2024-12-01 04:32:15

我显示的就是R 加后面一大段乱码

为什么会这样?
首先这个程序就是一个有错误的
就是有一个BUG
printf("%s\n",str); 这句是显示一个字符串

字符串的标志是什么 是'\0'
所以只有遇到'\0' 才会停止打印
str[0] 确定是R

但是后面的就不确定了
知道遇到'\0' 才停下
你打印出RRXY是 运气 每台电脑都不一样
追问
这种情况下,
在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’只和字符串有关系