C语言字符数组有几种不同的初始化方式, 它们之间存在着一些差别.
char message1[] = {'h', 'e', 'l', 'l', 'o'};
执行上述初始化后内存情况为:
注意到字符数组并不是以 ‘\0’ 结尾.char message2[] = {'h', 'e', 'l', 'l', 'o', '\0'};
执行上述初始化后内存情况为:
手动加上了 ‘\0’ 字符.char message3[] = "hello"
执行上述初始化后内存情况为:
注意到与message2的初始化结果相同, 但是事实上这里的 “hello” 并不是字符串常量, 它只是字符串初始化列表, 可以根据上下文区分它们.char *message4 = "hello"
执行上述初始化后内存情况为:
message4实际上已经不是字符数组了, 而是一个指向字符的指针, 但是我们仍然可以像是用字符数组那样使用它. 尽管如此它与字符数组在内存空间上却大不相同, message4所指向内存中的内容是字符串起始字符 ‘h’ 的地址.char *message5[] = {"hello", "world", "!"}
执行上述初始化后内存情况为:
注意到 message5 每一个 “跨度” 的字节数实际上与硬件地址总线的位数有关, 因为message5所指向的内存中实际上存储的是地址编码.char message6[][6] = {"hi", "world", "!"}
执行上述初始化后内存情况为:
注意这种方式与方式5的区别, 显然方式5内存利用率更高, 但方式6更容易阅读.