1 sizeof('a')
printf("%d",sizeof('a'));
上面這條語(yǔ)句輸出 4 中燥。原因是 sizeof 取值時(shí)玄货,默認(rèn)把 'a' 當(dāng)作 ASCII 相應(yīng)的值即 97 ,等于 sizeof(97)=4
2比較浮點(diǎn)數(shù)和零的值的大小
double tmp = 0.3;
printf("%d",(int)(tmp*10));
首先看一下上面這段代碼,這段代碼在我電腦上輸出結(jié)果為 2 (不同編譯器輸出結(jié)果可能不同)代乃。其原因是 0.3 以 double 存儲(chǔ)時(shí)娇斩,其數(shù)據(jù)可能是 0.2999999999999...茅主。
printf("%.17f",tmp);
其輸出為
0.29999999999999999
因此 tmp*3 就會(huì)等于 2.99999999 部念。當(dāng)以 %d 十進(jìn)制輸出時(shí)會(huì)輸出 2 。
同理氨菇,當(dāng) tmp 賦值為 0.7 時(shí)儡炼,其輸出結(jié)果也有可能為 6 。
由上面的代碼查蓉,我們知道浮點(diǎn)數(shù)會(huì)有精度限制乌询,它輸出的值與我們?cè)O(shè)想的不一定完全一樣,總會(huì)存在誤差豌研。例如下面的代碼,其輸出為not equal妹田。
#include <stdio.h>
int main(int argc, char *argv[])
{
float data = 0.3;
if(data == 0.3)//判斷相等時(shí)進(jìn)行了轉(zhuǎn)換?
{
printf("equal\n");
}
else
{
printf("not equal\n");//輸出not equal
}
return 0;
}
因此要比較浮點(diǎn)數(shù)和零的大小鹃共,我們不用 == 來(lái)判斷鬼佣,而是設(shè)法轉(zhuǎn)化為 >= 或 <= 。
假設(shè)浮點(diǎn)變量的名字為 x霜浴,應(yīng)當(dāng)將
if( x == 0)// 隱含錯(cuò)誤的比較
轉(zhuǎn)化為
if((x >= -EPSINON) && (x <= EPSINON))
其中 EPSINON 是允許的誤差(即精度)晶衷。
#include <stdio.h>
int main()
{
// double tmp = 0.3; //0.3 0.7 坑
// printf("%d\n", (int)((tmp+0.00000001) *10));
float a = 0.1;
if(a*10 >= 1.0 - 0.0000001 && a*10 <= 1.0+0.000001)
{
printf("====");
}
else
{
printf("xxxx");
}
return 0;
}
3 printf 返回的是域?qū)?/h3>
4 a= b =c =d =e =5 賦值過(guò)程
= 運(yùn)算符的結(jié)合型是從右往左,其返回的是賦值后的值
故表達(dá)式可表示為
a = (b = (c = (d = (e = 5))));
將 5 賦給 e ,再將 e 賦給 e ... 直至將 b 賦給 a
5 a*=b+4 是如何理解的
首先阴孟,+ 的優(yōu)先級(jí)大于 *= ,故表達(dá)式進(jìn)一步表示為
a = a\*(b+4);
6 如何理解a+++b
其結(jié)果為(a++)+b晌纫。這涉及到編譯原理的大嘴法則。待研究永丝。锹漱。。
7優(yōu)先級(jí)問(wèn)題
xx = 1+1, 2+1, 3+1;//輸出2
xx = (1+1, 2+1, 3+1);//輸出4
首先慕嚷,我們知道 , 運(yùn)算符的優(yōu)先級(jí)是最低的哥牍,其結(jié)合型從左到右
第一條語(yǔ)句先執(zhí)行 xx = 1+1;直接給xx 賦值為2,接著再執(zhí)行2+1喝检,3+1等無(wú)關(guān)結(jié)果的語(yǔ)句砂心。
第二條語(yǔ)句由于有括號(hào)的存在,先執(zhí)行括號(hào)的內(nèi)容蛇耀,而逗號(hào)的結(jié)合性是從左到右辩诞,故返回的是最后一條語(yǔ)句 3 + 1。接著把 3 + 1 賦值給 xx 纺涤。故輸出為4译暂。
8 輸出與占位符不匹配時(shí)
不會(huì)進(jìn)行轉(zhuǎn)換抠忘,故輸出會(huì)亂
float fData = 3.33;
printf("%d\n",fData);//輸出0
printf("%d\n",f);//輸出為0
printf("f + i = %d\n",(f+i));//輸出為亂七八糟
printf("f + i = %d\n",(int)(f+i));//輸出為8
printf("f + i = %f\n",f+i);//8.400000
10 sizeof(float+long long)
#include <stdio.h>
int main(int argc, char *argv[])
{
float f;
long long LL;
printf("sizeof(f) = %d\n", sizeof(f));
printf("sizeof(LL) = %d\n", sizeof(LL));
printf("sizeof(f+LL = )%d\n",sizeof(f+LL));
return 0;
}
上述代碼輸出為
sizeof(f) = 4
sizeof(LL) = 8
sizeof(f+LL = )4
因?yàn)閒loat表示的最大值比long long表示的最大值大,所以long long 會(huì)被強(qiáng)制轉(zhuǎn)換為float外永,故等于sizeof(float)=4崎脉;
11 ++ 和 --同樣可以用在浮點(diǎn)型
float a = 1.78;
a++;
printf("%f",a);//輸出2.780000
12 sizeof是運(yùn)算符,不是函數(shù)伯顶,要注意其優(yōu)先級(jí)
char a = 1;int b = 10;
printf("sizeof a+b =%d\n",sizeof a+b);//輸出11囚灼,注意sizeof是關(guān)鍵字不是函數(shù),要注意其優(yōu)先級(jí)
13
#include <stdio.h>
int main()
{
int c = 10;
int d = 20;
printf(" value = %d \n", (1 ? c : ((++d)<10 ? 100 : 200)));
printf(" d = %d \n", d);
return 0;
}
輸出結(jié)果為
value = 10
d = 20
輸出d為20,并沒(méi)有進(jìn)行自增祭衩≡钐澹可是三目運(yùn)算符不是從右到左執(zhí)行的嗎?不應(yīng)該先執(zhí)行++d么掐暮?待解決