和有什么区别
char *key_str="kiwi";
和
char *key_str = strdup("kiwi");
例如:
int strCmp(void *vp1, void *vp2) {
char * s1 = (char *) vp1;
char * s2 = (char *) vp2;
return strcmp(s1, s2);
}
为什么*key_str
在函数中使用时它们的行为不同strCmp()
?
和有什么区别
char *key_str="kiwi";
和
char *key_str = strdup("kiwi");
例如:
int strCmp(void *vp1, void *vp2) {
char * s1 = (char *) vp1;
char * s2 = (char *) vp2;
return strcmp(s1, s2);
}
为什么*key_str
在函数中使用时它们的行为不同strCmp()
?
在 C 中,所有文字字符串实际上都是(实际上是只读的)字符数组。
和
char *str = "kiwi";
你str
指出这样一个数组的第一个元素。
它有点等价于
char internal_array_for_kiwi[5] = { 'k', 'i', 'w', 'i', '\0' };
char *str = &internal_array_for_kiwi[0];
该strdup
函数动态分配内存并将传递的字符串复制到此内存中,创建字符串的副本。
所以之后
char *str = strdup("kiwi");
你有两个包含相同内容的数组。
相当于
char internal_array_for_kiwi[5] = { 'k', 'i', 'w', 'i', '\0' };
char *str = malloc(strlen(internal_array_for_kiwi) + 1);
strcpy(str, internal_array_for_kiwi);
需要强调两者之间的一个重要区别:C 中的文字字符串不能被修改。试图修改这样的字符串会导致未定义的行为。数组不是const
,但实际上是只读的。
如果您创建自己的数组(作为数组或动态分配),那么您可以根据需要修改其内容,只要您不超出范围或更改字符串空终止符。
所以如果我们有
char *str1 = "kiwi";
char *str2 = strdup("kiwi");
然后
str1[0] = 'l'; // Undefined behavior, attempting to modify a literal string
str2[0] = 'l'; // Valid, strdup returns memory you can modify
因为文字字符串不能被修改,建议你const char *
在指向它们时使用:
const char *str1 = "kiwi";
要记住的另一件重要事情:由于strdup
动态分配内存(使用) ,一旦你完成了字符串,你就malloc
需要该内存:free
free(str2);
如果您不释放内存,那么您将有内存泄漏。
除此之外,这两种变体之间没有有效的区别。例如,在调用函数时,两者可以互换使用。