我认为a完全相同b.但跑步的结果证明我错了.我以错误的方式了解哪一部分?
这是代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(void)
{
char a[] = "abcdefg";
char b[] = {'a' , 'b' , 'c' , 'd' , 'e' , 'f' , 'g'};
printf("%s\n" , a);
printf("%s\n" , b);
system("pause");
return 0;
}
Run Code Online (Sandbox Code Playgroud)
Dav*_*bin 10
当C编译器找到以下代码时
char a[] = "abcdefgh";
Run Code Online (Sandbox Code Playgroud)
它实际上留出了足够的内存来存储9个字符,你在字符串中包含的8个字符加上一个额外的字符来保存0,这是一个空字符.C使用nul字符标记字符串的结尾.没有它,没有一个C字符串函数能够分辨出字符串结尾在内存中的位置.
代码
char b[] = {'a', 'b', 'c', 'd', 'e', 'f', 'g'};
Run Code Online (Sandbox Code Playgroud)
明确告诉C为8个字符保留存储空间并将它们设置为您给出的值.没有指定nul终止符(即结尾没有0),所以C函数赢了; t能够判断这个字符串有多长.
printf("%s\n" , a);
Run Code Online (Sandbox Code Playgroud)
告诉C打印从内存中的地址a开始找到的字符串.它会一直打印字符,直到它找到编译器为您安静地放入的0终止符.
printf("%s\n" , b);
Run Code Online (Sandbox Code Playgroud)
告诉C打印从内存中的地址b开始找到的字符串.它会一直打印字符,直到它找到0终结符,但由于你没有在数组中放置一个,它会继续打印出你定义的数组后内存中的内容,直到遇到0.
要解决此问题,您需要明确告诉编译器在其他字符之后放置0.您可以使用特殊字符\ 0执行此操作,如下所示:
char b[] = {'a' , 'b' , 'c' , 'd' , 'e' , 'f' , 'g', '\0' };
Run Code Online (Sandbox Code Playgroud)