最近在閱讀《c和指標》這本書,對c語言的分析很不錯,這是繼《c++ primer》之後感覺又一部比較適合我閱讀的書了,值得推薦,其中有些比較有趣的用法拿出來和大家分享。首先我們回憶關於字元陣列和字串常量的區別,比較下面兩個語句:
char p = 「hello world!」;
char* p = 「hello world!」;
第乙個為字元陣列的初始化,包含13個字元,注意最後有個』\0』,第二個為初始化指標變數,它指向字串常量的儲存位置。我們知道計算機的資料有三個儲存區:靜態儲存區、棧和堆,第乙個字串存在棧區,第二個指向靜態儲存區。
當字串常量出現於表示式中時,它的值是個指標常量。編譯器把這些指定字元的乙份拷貝儲存在記憶體的某個位置,並儲存乙個指向第乙個字元的指標。
下面的表示式是什麼意思呢?
「xyz」+1
當你記得字串常量實際是個指標時,它的意義就變得清楚了,它計算指標值加1的值,它的結果是個指標,指向字串第二個字元:y
那麼這個表示式又是什麼呢?
*」xyz」
對乙個指標執行間接訪問操作,其結果就是指標所指向的內容。所以它的值是指向的字元:x,注意不是整個字串。
下乙個寫法更奇怪,
」xyz」[2]是什麼意思呢?
根據以上知識,我們可以推斷出應該是z。
由此,我們把二進位制轉化為字元的實現可以很簡單的實現:
unsigned value;
putchar(「0123456789abcdef」[value%16]);
思考下面的神奇函式的意義。
#include
void mystery(int n)
常量,字串常量
對於普通變數常量 常量摺疊 是 就是在編譯器進行語法分析的時候,將常量表示式計算求值,並用求 得的值來替換表示式,放入常量表。可以算作一種編譯優化 include void main 輸出 3 2 我只是改了這個位址內容,但是e還是2,因為編譯器在優化的過程中,會把碰見的const全部以內容替換掉 ...
字串常量
1.當乙個字串常量出現於表示式中時,它的值是乙個指標常量。編譯器被這些指定字元的乙份拷貝儲存在記憶體的某個位置,並儲存乙個指向第乙個字元的指標。陣列名用於表示式中時,它的值也是指標常量 2.xyz 1 因為字串常量實際上是個常量指標,這個表示式計算 指標值加上1 的數值。它的結果是個指標,指向字串中...
字串常量
來自 常量字串為什麼位於靜態儲存區?char c chenxi 書上說 chenxi 這個字串被當作常量而且被放置在此程式的記憶體靜態區。那一般的int i 1 1也是常量,為什麼1就不被放置在此程式的記憶體靜態區了呢?請高手指點!所有的字元竄常量都被放在靜態記憶體區 因為字串常量很少需要修改,放在...