1.概念
字符数组,数组元素是char(字符型)的数组,它可以是一维数组,也可以是二维数组。
2.定义的时候赋值
char ch1[]={'c','h','i','n','a'};
char ch2[]={"china"}; //相当于 char ch2[] = "china"; 元素个数为6,默认会在后面加一个'\0'
这两者有何区别呢?
第一种方式:显式初始化但不包含空字符
char c1[] = {'c', 'h', 'i', 'n', 'a'};
这行代码定义了一个名为 c1
的字符数组,并显式地初始化了它的前五个元素,分别是 'c'
, 'h'
, 'i'
, 'n'
, 和 'a'
。这里没有指定数组的大小,但C语言会根据初始化列表中元素的数量自动确定数组的大小,即在这个例子中是5个元素。
重要的是要注意,这个数组没有包含字符串的终结符 '\0'
。在C语言中,字符串是以空字符('\0'
)结尾的字符序列。因此,c1
实际上并不是一个以空字符结尾的字符串,尽管它包含了一系列看起来像字符串的字符。
如果你尝试将 c1
作为字符串来处理(比如使用 printf("%s", c1);
),那么 printf
函数会继续读取内存直到遇到第一个 '\0'
为止。由于 c1
没有包含 '\0'
,这可能会导致未定义行为,比如打印出 c1
后面的内存内容,直到遇到某个随机位置的 '\0'
为止。
第二种方式:使用字符串字面量初始化
char c2[] = "china";
或者等价地:
har c2[] = {"china"};
这两行代码都定义了一个名为 c2
的字符数组,并使用字符串字面量 "china"
来初始化它。在C语言中,字符串字面量实际上是一个以空字符 '\0'
结尾的字符数组。因此,当使用字符串字面量来初始化字符数组时,编译器会自动在数组的末尾添加一个 '\0'
。
在这个例子中,c2
数组实际上包含六个元素:'c'
, 'h'
, 'i'
, 'n'
, 'a'
, 和 '\0'
。这使得 c2
可以安全地作为字符串来使用,因为它以空字符正确终结。
尝试使用 printf("%s", c2);
打印 c2
时,printf
会正确地读取字符直到遇到 '\0'
为止,因此会打印出 "china"
。
小总结
- 第一种方式定义了一个不包含空字符的字符数组,它不能安全地作为字符串使用。
- 第二种方式定义了一个包含空字符的字符数组(通过字符串字面量),它可以安全地作为字符串使用。
3.注意事项
如果字符数组在定义的时候没有赋值,只能通过元素单个赋值或者字符串操作函数进行赋值
char string[6];
string[0] = 'h';
string[1] = 'e';
strcpy(string,"hello");
特别注意:以下这种写法是错误的
char string[6];
string[6] = "hello";//错误
string = "hello";//也是错误的
原因:数组元素的访问只能是通过单个元素进行的,所以string[6]是错误的;数组的名字经过编译之后其实就是一个地址,也就是常量(比如可能是0x00ff110f),所以给一个地址赋值是错误的,string = "hello";//也是错误的。
结语: 以上是我对字符数组的理解。字符数组用于存储字符串,字符串以空字符('\0'
)结尾。初始化时需确保字符串正确终结,避免未定义行为。感谢阅读,欢迎指正!