單片機(jī)c語言教程:C51運算符和表達(dá)式(指針和地址運算符)
sizeof 運算符看上去這確實是個奇怪的運算符,有點像函數(shù),卻又不是。大家看到 size 應(yīng)該就猜到 是和大小有關(guān)的吧?是的,sizeof 是用來求數(shù)據(jù)類型、變量或是表達(dá)式的字節(jié)數(shù)的一個運 算符,但它并不像“=”之類運算符那樣在程序執(zhí)行后才能計算出結(jié)果,它是直接在編譯時 產(chǎn)生結(jié)果的。它的語法如下:
sizeof (數(shù)據(jù)類型)
sizeof (表達(dá)式) 下面是兩句應(yīng)用例句,程序大家能試著編寫一下。
printf(char 是多少個字節(jié)? ½ 字節(jié)n,sizeof(char));
printf(long 是多少個字節(jié)? ½ 字節(jié)n,sizeof(long));
結(jié)果是:
char 是多少個字節(jié)? 1 字節(jié)
long 是多少個字節(jié)? 4 字節(jié)
強(qiáng)制類型轉(zhuǎn)換運算符 不知你們是否有自己去試著編一些程序,從中是否有遇到一些問題?開始學(xué)習(xí)時我就遇到過這樣一個問題:兩個不一樣數(shù)據(jù)類型的數(shù)在相互賦值時會出現(xiàn)不對的值。如下面的一段小程序:
void main(void)
{
unsigned char a;
unsigned int b;
b=100*4;
a=b;
while(1);
}
這段小程序并沒有什么實際的應(yīng)用意義,如果你是細(xì)心的朋友定會發(fā)現(xiàn) a 的值是不會等于100*4 的。是的 a 和 b 一個是 char 類型一個是 int 類型,從以前的學(xué)習(xí)可知 char 只占一個 字節(jié)值最大只能是 255。但編譯時為何不出錯呢?先來看看這程序的運行情況:
圖 9-3 小程序的運行情況
b=100*4 就能得知 b=0x190,這個時候我們能在 Watches 查看 a 的值,對于 watches 窗口我們 在第 5 課時簡單學(xué)習(xí)過,在這個窗口 Locals 頁里能查看程序運行中的變量的值,也能在 watch 頁中輸入所要查看的變量名對它的值進(jìn)行查看。做法是按圖中 1 的 watch#1(或watch#2),然后光標(biāo)移到圖中的 2 按 F2 鍵,這樣就能輸入變量名了。在這里我們能查看到 a 的值為 0x90,也就是 b 的低 8 位。這是因為執(zhí)行了數(shù)據(jù)類型的隱式轉(zhuǎn)換。隱式轉(zhuǎn)換是 在程序進(jìn)行編譯時由編譯器自動去處理完成的。所以有必要了解隱式轉(zhuǎn)換的規(guī)則:
c語言相關(guān)文章:c語言教程
評論