二、代碼
#include <stdio.h>
int main()
{
// 保存字符串
char str[] = "lyh";
printf("str = %s\n",str);
str[0] = 's';
printf("str = %s\n",str);
// 因為數組名就是數組的地址,數組名保存的就是數組的第0個元素的地址,所以我們可以使用指針 來保存字符串
// 通過指針保存一個字符串, 其實就是保存的字符串 第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);
// 通過數組保存字符串 和 通過指針保存字符串的區別
// 如果通過 數組來保存字符串 , 那么字符串是一個變量 str 可以修改
// 如果通過 指針來保存字符串 , 那么字符串是一個常量 str2 不能修改
// 數組保存的字符串 存儲在內存的 棧中,而通過 指針保存的字符串 存儲在 常量區
// 存儲在 棧中的變量有一個特點, 當作用域結束, 系統就會自動釋放該變量
// 存儲在 常量去 的值有一個特點, 不會被釋放,而且多個相同的值 對應的地址相同
// 利用指針保存字符串的應用場景
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";
存儲的位置 : 棧
特點 : 相同的字符串 會重復的分配存儲空間
字符串可以修改
char *str = "lyh";
存儲的位置 : 常量區
特點 : 相同的字符串 不會重復的分配存儲空間
字符串不可以修改
*/
return 0;
}
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。