昨天上c++選修,老師指出了乙個我以前沒怎麼注意的問題,形如
"char * pstr="abcd";"的語句中的pstr指向的是字串常量,所以程式中對pstr指向的區
域只能讀,
不能寫,否則即算編譯成功,也會執行失敗。
剛剛結合網上資料,對這個情況實驗了一下,有如下結論,和大家共享下.
1.pstr指向的"abcd"是字串常量,編譯後存放在記憶體中的資料區(即存放全域性變數和靜態局
部變數的地 方)
2."abcd"的存放位置和靜態區域性變數一致,其生存期也和靜態區域性變數一樣具有程式生存期
(事實上生存
期和存放區域是對應的)。不過與靜態全域性變數不同的是,它是唯讀的。
3."abcd"這個字串應與"const char pstr2="abcd"與以區分,後者有可能是存放在棧區
(auto變數
就放在這裡),當然有些編譯器對const作了優化,也有放其他地方的.
由上述結論應該可以很快推出下面測試程式的結果
#include
using namespace std;
char * test();
int main()
{char * p=test();
cout<
char * test()
{char * str1="i want to get the answer.";
char * str2="i want to get the answer.";
char * str3="i want to get the answer.";
char str4="i want to get the answer.";
char str5="i want to get the answer.";
cout<
輸出是(vc6.0)
46f02c,46f02c,46f02c,12fefc,12fee0
i want to get the answer.
46fc02c
可以看到
1.str1,str2,str3這三個位址指標的值一樣,而後面兩個指標位址值相異。為什麼這樣?從
前文中可找
到答案。
2.cout<
常量,字串常量
對於普通變數常量 常量摺疊 是 就是在編譯器進行語法分析的時候,將常量表示式計算求值,並用求 得的值來替換表示式,放入常量表。可以算作一種編譯優化 include void main 輸出 3 2 我只是改了這個位址內容,但是e還是2,因為編譯器在優化的過程中,會把碰見的const全部以內容替換掉 ...
字串常量
1.當乙個字串常量出現於表示式中時,它的值是乙個指標常量。編譯器被這些指定字元的乙份拷貝儲存在記憶體的某個位置,並儲存乙個指向第乙個字元的指標。陣列名用於表示式中時,它的值也是指標常量 2.xyz 1 因為字串常量實際上是個常量指標,這個表示式計算 指標值加上1 的數值。它的結果是個指標,指向字串中...
字串常量
來自 常量字串為什麼位於靜態儲存區?char c chenxi 書上說 chenxi 這個字串被當作常量而且被放置在此程式的記憶體靜態區。那一般的int i 1 1也是常量,為什麼1就不被放置在此程式的記憶體靜態區了呢?請高手指點!所有的字元竄常量都被放在靜態記憶體區 因為字串常量很少需要修改,放在...