char *a 与char a[] 的区别和char** argv与char *argv[]区别
生活随笔
收集整理的這篇文章主要介紹了
char *a 与char a[] 的区别和char** argv与char *argv[]区别
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
char *a 與char a[] 的區別
char *a = "hello" 中的a是指向第一個字符‘a'的一個指針
char a[20] = "hello" 中數組名a也是執行數組第一個字符‘h’的指針
但二者并不相同:
看實例:把兩個字符串相加:
結果:
hello0123456789
對比:
Segmentation fault
把字符串加到指針所指的字串上去,出現段錯誤,本質原因:*d="0123456789"存放在常量區,是無法修的。而數組是存放在棧中,是可以修改的。兩者區別如下:
一. ”讀“ ”寫“ 能力
- char *a = "abcd"; ?此時"abcd"存放在常量區。通過指針只可以訪問字符串常量,而不可以改變它。
- 而char a[20] = "abcd"; 此時?"abcd"存放在棧。可以通過指針去訪問和修改數組內容。
二. 賦值時刻
- char *a = "abcd"; 是在編譯時就確定了(因為為常量)。
- 而char a[20] = "abcd"; 在運行時確定
三. 存取效率
- char *a = "abcd"; 存于靜態存儲區。在棧上的數組比指針所指向字符串快。因此慢
- 而char a[20] = "abcd";?存于棧上。快
另外注意:
char a[] = "01234",雖然沒有指明字符串的長度,但是此時系統已經開好了,就是大小為6-----'0' '1' '2' '3' '4' '5' '\0',(注意strlen(a)是不計‘\0’)
看一結構中出現的同樣的問題:
這樣紅色部分在調用Init函數時會出現“Segment Default", 因為此時 指針n是靜態的,只有“讀”的本事,不可以改變。
?
內存分配方式
內存分配有三種:靜態存儲區、堆區和棧區。他們的功能不同,對他們使用方式也就不同。
char** argv與char *argv[]區別
指針是個地址。 char *a: a的值包含字符型數據,取消對a的引用(*a)得到一個字符, 不取消引用得到一個字符串,printf("%c",*a)輸出一個字符或者printf("%s",a)輸出字符串; char **a: a的值包含一個地址,該地址包含字符字符型數據,取消對a的引用(*a),得到該地址,再取消對該地址的引用(**a),得到一個字符,printf("%c",**a)輸出一個字符printf("%s",*a)輸出字符串; char *a[]: a是一個數組,數組的元素是地址(地址其實就是指針),地址包含的值是字符型數據,printf("%c",*a[i])輸出一個字符,printf("%s",a[i]))輸出字符串; char *a或char **a可以改變a的值,char a*[]不能改變a的值。
總結
以上是生活随笔為你收集整理的char *a 与char a[] 的区别和char** argv与char *argv[]区别的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java.io.File.setExec
- 下一篇: 深入 char * ,char ** ,