1、隱式轉換
c在以下四種情況下會進行隱式轉換:
1、算術表示式中,低型別能夠轉換為高型別。
2、賦值表示式中,右邊表示式的值自動隱式轉換為左邊變數的型別,並賦值給他。
3、函式呼叫中引數傳遞時,系統隱式地將實參轉換為形參的型別後,賦給形參。
4、函式有返回值時,系統將隱式地將返回表示式型別轉換為返回值型別,賦值給呼叫函式。
2、算數運算的隱式轉換
算數運算中,首先有如下型別轉換規則:
1、字元必須先轉換為整數(c語言規定字元型別資料和整型資料之間可以通用) 。
2、short型轉換為int型(同屬於整型) 。
3、float型資料在運算時一律轉換為雙精度(double)型,以提高運算精度(同屬於實型) 。
其次,有下面的規則。
當不同型別的資料進行操作時,應當首先將其轉換成相同的資料型別,然後進行操作,轉換規則是由低階向高階轉換。轉換規則如下圖所示:
有符號數與無符號數之間運算問題
以下實驗均在virual c++6中執行通過
這個問題測試是否懂得c語言中的
整數自動轉換原則,有些開發者懂得極少這些東西。當表示式中存在有符號型別和無符號型別時所有的運算元都自動轉換為
無符號型別。因此,從這個意義上講,無符號數的運算優先順序要高於有符號數,這一點對於應當頻繁用到無符號資料型別的嵌入式系統來說是丰常重要的。
首先進行乙個實驗,分別定義乙個signed int型資料和unsigned int型資料,然後進行大小比較:
unsigned int a=20;
signed int b=-130;
a>b?還是b>a?實驗證明b>a,也就是說-130>20,為什麼會出現這樣的結果呢?
這是因為在c語言操作中,如果遇到無符號數與有符號數之間的操作,編譯器會自動轉化為無符號數來進行處理,因此a=20,b=4294967166,這樣比較下去當然b>a了。
(c語言有符號整型最高位即第32位為符號為,正數字0,負數為1,因此在轉換為無符號整型時最高位的1按實際有意義的數認為,即加上了2^31,原作者認為是32次方,我不敢苟同
)再舉乙個例子:
unsigned int a=20;
signed int b=-130;
std::cout<
減法和乘法的運算結果類似。
如果作為signed int型資料的b=-130,b與立即數之間操作時不影響b的型別,運算結果仍然為signed int型:
signed int b=-130;
std::cout<
[cpp]view plain
copy
#include
/*當表示式中存在符號型別和無符號型別時
所有的運算元都自動轉換為無符號型別
*/using
namespace
std;
char
getchar(
intx,
inty)
void
main()
答案: c1 = 1 c2= 2 c3= 2 c4= 1
這樣乙個題,據說是微軟面試題:
unsigned int i=3;
cout問結果是多少。
第一反應:-3。不過結果似乎不是這樣的,寫了個程式,執行了一下,發現是:
4294967293。很詭異的乙個數字,怎麼也想不明白為什麼會是這麼個奇怪的數字。但是在我發現這數的十六進製制數是fffffffd時,我想我已經離答案很近了...
這個涉及到了混合著不同資料型別的表示式中的資料型別的轉換問題。在總結轉換問題之前,先說明一下各種資料型別(只說明numeric型別的),下表來自msdn:
對上表補充說明一下:
1)在32位機上,int型和unsigned int型都是32位的(4個位元組)。
2)enum會跟據最大值來決定型別,一般來說為int型,如果超出int型所能表示的範圍,則用比int型大的最小型別來表示(unsigned int, long
或者unsigned long)
3)關於型別的大小。一般用所能表示的資料範圍來比較型別的大小,如char型
下面結合自己查的資料,加上自己不斷地舉各種情況程式設計,總結一下關於型別轉換(僅限於算術表示式中關於整數型別的轉換)的一些問題(如有缺漏,歡迎補充,感激不盡)
1、所有比int型小的資料型別(包括char,signed char,unsigned char,short,signed short,unsigned short)轉換為int型。如果轉換後的資料會超出int型所能表示的範圍的話,則轉換為unsigned int型;
2、bool型轉化為int型時,false轉化為0,true轉換為1;反過來所有的整數型別轉化為bool時,0轉化為false,其它非零值都轉為true;
3、如果表示式中混有unsigned short和int型時,如果int型資料可以表示所有的unsigned short型的話,則將unsigned short型別的資料轉換為int型,否則,unsigned short型別及int型都轉換為unsigned int型別。舉個例子,在32位機上,int是32位,範圍–2,147,483,648 to 2,147,483,647,unsigned short是16位,範圍0 to 65,535,這樣int型的足夠表示unsigned short型別的資料,因此在混有這兩者的運算中,unsigned short型別資料被轉換為int型;
4、unsigned int 與long型別的轉換規律同3,在32位機上,unsigned int是32位,範圍0 to 4,294,967,295,long是32位,範圍–2,147,483,648 to 2,147,483,647,可見long型別不夠表示所有的unsigned int型,因此在混有unsigned int及long的表示式中,兩者都被轉換為unsigned long;
5、如果表示式中既有int 又有unsigned int,則所有的int資料都被轉化為unsigned int型別。
經過這番總結,前面提出的問題的答案應該就很明顯了吧。在表示式i*-1中,i是unsigned int型,-1是int型(常量整數的型別同enum),按第5條可以知道-1必須轉換為unsigned int型,即0xffffffff,十進位制的
4294967295,然後再與i相乘,即4294967295*3,如果不考慮溢位的話,結果是12884901885,十六進製制0x2fffffffd,由於unsigned int只能表示32位,因此結果是0xfffffffd,即4294967293。
C語言運算中的資料型別自動轉換原則
1 隱式轉換 c在以下四種情況下會進行隱式轉換 1 算術表示式中,低型別能夠轉換為高型別。2 賦值表示式中,右邊表示式的值自動隱式轉換為左邊變數的型別,並賦值給他。3 函式呼叫中引數傳遞時,系統隱式地將實參轉換為形參的型別後,賦給形參。4 函式有返回值時,系統將隱式地將返回表示式型別轉換為返回值型別...
php運算資料型別自動轉換
空字串 或 數字0 或0.0 字元 0 或 0 空值 null 沒有成員的陣列 其餘都轉換成布林型 true,包含資源 如果字串為合法的數字字串,則直接轉換成整型 浮點型 如果字串中包含.或 e或e,則轉換成浮點型 否則轉換成整型 非法的數字字串轉換成數值0 布林型true 轉換成數字 1,fals...
C語言資料型別轉換
自動轉換發生在不同資料型別的量混合運算時,由編譯系統自動完成。自動轉換遵循以下規則 若參與運算量的型別不同,則先轉換成同一型別,然後進行運算。轉換按資料長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先把int量轉成long型後再進行運算。所有的浮點運算都是以雙精度進行的,即使僅...