淺析C語言中對于char*和char[]的理解
C語言對于char*和char[]的理解
1、char*和char[]的共同點
都是指針,指向第一個字符所在的地址,C語言指針可以代替數組使用。
指針也是一種變量,只不過它的內存單元中保存的是一種標識其他位置的地址,而地址也是整數,在32位平臺下,就是32位,4個字節(jié)
指針的指向是指 指針變量所保存的其他的地址單元中 所存放的數據類型。
int *ptr; //ptr指針保存的地址所在內存單元中的數據類型是整型 float *p; //這個p指針指向的內存地址存放的元素類型就是浮點型
而不管指向的數據類型是哪種,其實對于指針本身的值永遠是整型,因為它保存的地址就是整數。
2、char*的用法

3、char[]的用法
//char[]
char a[20] = "aaa";
char b[] = "bbbbb";
char c[] = {'s','t','r','i','n','g','\0'};
char d[] = {"dddd"};
//一般這樣初始化
char num[20] = {0};
//初始化的目的是為了添加\0,否則\0會跑到莫名其妙的地方導致很多錯誤。
//ASCII碼中0對應的是nul符,即\0。這一行的意義就是給0~19都賦\0。4、怎么輸出char*地址
雖然指針名就代表的是地址,但在輸出時需要加&,僅限cout。
const char* p = "ppp"; cout<<&p<<endl; //地址 方法一 cout<<(void*)p<<endl;//地址 方法二 cout<<p<<endl; //ppp
const char* a = "ppp";
printf("%p \n", a); //16進制地址,不過 %p的輸出格式并不統(tǒng)一,有的編譯器帶0x前綴,有的不帶
printf("%#X \n", a);//16進制地址,前綴統(tǒng)一是0x
printf("%s \n", a); //ppp5、strlen和sizeof
| sizeof | strlen | |
| 性質 | 運算符 | 函數 |
| 功能 | 以字節(jié)為單位計算操作數占用的內存大小 | 計算字符串的長度(strlen函數遇到\0就會停止下來,返回\0前出現的字符個數,不包括\0) |
| 時間 | 編譯時 | 運行時 |
| 參數 | 類型/各種object | const char*\char*\char[] |
| 返回值 | size_t | size_t |
| 頭文件 | 運算符沒有頭文件 | string.h |
6、char*和string
| 區(qū)別 | string | char* |
| 本質 | STL中的一個容器,string封裝了char*。 | 指針 |
| 內存管理 | 由系統(tǒng)管理,除非系統(tǒng)內存池用完,否則不會出現內存問題 | 棧/堆,如果是堆需要手動釋放 |
7、總結
1、const在*前修飾指定的類型,const在*之后修飾指針。
2、 讀入只能是char [],因為讀入需要明確的地址,注意必須標定長度。
總結:char * s 只是一個保存字符串首地址的指針變量,char a[]是許多連續(xù)的內存單元,單元中的元素是char型,char * 和 char a[]具有相同的效果,源于字符串的本質,即給一個字符串地址,便可以操作字符串,但char* 和 char a[]的本質屬性不一樣。
改值還得是char*,因為方便。
Reference
到此這篇關于C語言中對于char*和char[]的理解的文章就介紹到這了,更多相關C語言char*和char[]內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

