字符串的输入方式——“XXXX”
#include<stdio.h>
int main(void)
{
char arr[10] = "abcd";
return 0;
}
具体的内存分布
字符串的输入方式——‘X’ ,‘X’
#include<stdio.h>
int main(void)
{
char arr1[] = "abcd";
char arr2[] = { 'a','b','c' };
return 0;
}
这个是两种输入方式的不同的内存分布,要注意:
第一种方式比第二种内存多保留了一个\0
首先是字符串的两种输入方式
char arr1[] = "abc";
char arr2[] = { 'a','b','c'};
大体来说就是这两种的形式啦,但是,真的是这样吗???
不管怎样,来看一下输出结果吧:
为什么第二个如此的魔性?
原来是因为第一个自带\0,但是第二个没有,而这个\0呢是判断结束的标志,第二个没有当然会出现这样的一大堆东西啦。
第二个如何改进呢?
在后面加上\0或0就可以判断为字符串结束的标志了
为什么\0和0都可以呢?
因为在ASCII总\0就是0啦,所以它俩可以互换。
其次是字符串长度看\0
#include<stdio.h>
#include<string.h>
int main(void)
{
char arr1[] = "abcd";
char arr2[] = { 'a', 'b', 'c', 'd' };
printf("%d\n", strlen(arr1));
printf("%d\n", strlen(arr2));
return 0;
}
这样看更加的能够看出来这两种输入是怎么回事拉,也呼应了上面那个例子
这里的16是随机值哦,
改动之后:
#include<stdio.h>
#include<string.h>
int main(void)
{
char arr1[] = "abcd";
char arr2[] = { 'a', 'b', 'c', 'd',0 };
printf("%d\n", strlen(arr1));
printf("%d\n", strlen(arr2));
return 0;
}
这样两个就一样了,更加证实了0和\0是一样的。
另外,strlen是不计入\0的,只计入\0之前的内容。
补充-------指定数组长度
char arr2[10] = { 'a','b','c' };
char arr3[] = { 'a','b','c' };
指定数组长度的话后边就自动补充\0了
一下输出为证:
注意第二种方式所开辟的空间!!!
#include<stdio.h>
int main(void)
{
char a[] = { 'a', 'b', 'c' };
printf("%d", sizeof(a));
return 0;
}
答案是【3】
内存是只分配了三个空间,所以sizeof为3
但是strlen因为没有看到\0所以是随机值
2021.2.25我又回来了。还是对下面的代码产生了怀疑
#include<stdio.h>
int main(void)
{
char a[] = { 'a', 'b', 'c' };
printf("%d\n", sizeof(a));
return 0;
}
还是和strlen弄混了,记住这里用内存来解释。就开辟了三个字节的字符类型/!!!