字元陣列VS字元指標

2021-05-22 01:56:23 字數 1344 閱讀 5496

1.以字串形式出現的,編譯器都會為該字串自動新增乙個0作為結束符,如在**中寫"abc",那麼編譯器幫你儲存的是"abc/0"

2."abc"是常量嗎?答案是有時是,有時不是。

不是常量的情況:

"abc"作為字元陣列初始值的時候就不是,如char str = "abc";因為定義的是乙個字元陣列,所以就相當於定義了一些空間來存放"abc",而又因為字元陣列就是把字元乙個乙個地存放的,所以編譯器把這個語句解析為char str[3] = ;又根據上面的總結1,所以char str = "abc";的最終結果是char str[4] = ;做一下擴充套件,如果char str = "abc";是在函式內部寫的話,那麼這裡的"abc/0"因為不是常量,所以應該被放在棧上。

是常量的情況: 

把"abc"賦給乙個字元指標變數時,如char* ptr = "abc";因為定義的是乙個普通指標,並沒有定義空間來存放"abc",所以編譯器得幫我們找地方來放"abc",顯然,把這裡的"abc"當成常量並把它放到程式的常量區是編譯器最合適的選擇。所以儘管ptr的型別不是const char*,並且ptr[0] = 'x';也能編譯通過,但是執行ptr[0] = 'x';就會發生執行時異常,因為這個語句試圖去修改程式常量區中的東西。記得哪本書中曾經說過char* ptr = "abc";這種寫法原來在c++標準中是不允許的,但是因為這種寫法在c中實在是太多了,為了相容c,不允許也得允許。雖然允許,但是建議的寫法應該是const char* ptr = "abc";這樣如果後面寫ptr[0] = 'x'的話編譯器就不會讓它編譯通過,也就避免了上面說的執行時異常。又擴充套件一下,如果char* ptr = "abc";寫在函式體內,那麼雖然這裡的"abc/0"被放在常量區中,但是ptr本身只是乙個普通的指標變數,所以ptr是被放在棧上的,只不過是它所指向的東西被放在常量區罷了。

3.陣列的型別是由該陣列所存放的東西的型別以及陣列本身的大小決定的。

如char s1[3]和char s2[4],s1的型別就是char[3],s2的型別就是char[4],也就是說儘管s1和s2都是字元陣列,但兩者的型別卻是不同的。

4.字串常量的型別可以理解為相應字元常量陣列的型別,如"abcdef"的型別就可以看成是const char[7]

5.sizeof是用來求型別的位元組數的。如int a;那麼無論sizeof(int)或者是sizeof(a)

6.#include

#include

using namespace std;

int main(int argc, char *argv)

;int i=0;

cout<<*p++

return exit_success;

}

字元陣列VS字元指標

1.以字串形式出現的,編譯器都會為該字串自動新增乙個 0作為結束符,如在 中寫 abc 那麼編譯器幫你儲存的是 abc 0 2.abc 是常量嗎?答案是有時是,有時不是。不是常量的情況 abc 作為字元陣列初始值的時候就不是,如 char str abc 因為定義的是乙個字元陣列,所以就相當於定義了...

字元陣列VS字元指標

1.以字串形式出現的,編譯器都會為該字串自動新增乙個 0作為結束符,如在 中寫 abc 那麼編譯器幫你儲存的是 abc 0 2.abc 是常量嗎?答案是有時是,有時不是。不是常量的情況 abc 作為字元陣列初始值的時候就不是,如 char str abc 因為定義的是乙個字元陣列,所以就相當於定義了...

字元陣列VS字元指標

1.以字串形式出現的,編譯器都會為該字串自動新增乙個 0作為結束符,如在 中寫 abc 那麼編譯器幫你儲存的是 abc 0 2.abc 是常量嗎?答案是有時是,有時不是。不是常量的情況 abc 作為字元陣列初始值的時候就不是,如 char str abc 因為定義的是乙個字元陣列,所以就相當於定義了...