二驮宴、代碼
#include <stdio.h>
int main()
{
// 保存字符串
char str[] = "lyh";
printf("str = %s\n",str);
str[0] = 's';
printf("str = %s\n",str);
// 因?yàn)閿?shù)組名就是數(shù)組的地址,數(shù)組名保存的就是數(shù)組的第0個元素的地址,所以我們可以使用指針 來保存字符串
// 通過指針保存一個字符串, 其實(shí)就是保存的字符串 第0個元素的地址
char *str2 = "lyh";
printf("str2 = %s\n",str2);
// str2[0] = 's';
char *str3 = "lyh";
printf("str = %p\n",str);
printf("str2 = %p\n",str2);
printf("str3 = %p\n",str3);
// 通過數(shù)組保存字符串 和 通過指針保存字符串的區(qū)別
// 如果通過 數(shù)組來保存字符串 , 那么字符串是一個變量 str 可以修改
// 如果通過 指針來保存字符串 , 那么字符串是一個常量 str2 不能修改
// 數(shù)組保存的字符串 存儲在內(nèi)存的 棧中,而通過 指針保存的字符串 存儲在 常量區(qū)
// 存儲在 棧中的變量有一個特點(diǎn), 當(dāng)作用域結(jié)束, 系統(tǒng)就會自動釋放該變量
// 存儲在 常量去 的值有一個特點(diǎn), 不會被釋放,而且多個相同的值 對應(yīng)的地址相同
// 利用指針保存字符串的應(yīng)用場景
for (int i = 0; i < 100; i++) {
// 意味著會開辟 100塊存儲空間 來保存hehe這個字符串
// 并且會釋放100次
// char str4[] = "hehe";
char *str5 = "hh";
// printf("str4 = %p\n",str4);
printf("str5 = %p\n",str5);
}
/*
保存 字符串的兩種方式:
char str[] = "lyh";
存儲的位置 : 棧
特點(diǎn) : 相同的字符串 會重復(fù)的分配存儲空間
字符串可以修改
char *str = "lyh";
存儲的位置 : 常量區(qū)
特點(diǎn) : 相同的字符串 不會重復(fù)的分配存儲空間
字符串不可以修改
*/
return 0;
}
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者