C語言基礎隱式類型轉換與強制類型轉換示例解析
類型轉換
數據有不同的類型,不同類型數據之間進行混合運算時必然涉及到類型的轉換問題。
轉換包括隱式類型轉換和強制類型轉換。
類型轉換的原則:占用內存字節數少(值域小)的類型,向占用內存字節數多(值域大)的類型轉換,以保證精度不降低。
隱式類型轉換
隱式轉換也稱為自動轉換,遵循一定的規則,由編譯器自動完成。
C的整型算數運算總是至少以缺省整型類型的精度來進行,為瞭獲得這個精度,表達式中的字符和短整形操作數在使用之前都被轉換成普通整型,這種轉換為整型提升。
整型提升:通用CPU是難以直接實現兩個8比特位直接相加運算。所以表達式中各種長度可能小於int長度的整型值,都必須轉換為int或者unsigned int ,然後才能送入CPU去執行運算。
代碼示例1:
int main() { char a = 5, b = 126; //5:00000000 00000000 00000000 00000101 //a:0000 0101(截斷操作) //126:00000000 00000000 00000000 01111110 //b:0111 1110 //當a和b相加時,都是char類型,就會發生整型提升 //int c = 000000000000000000000000 00000101 + 000000000000000000000000 01111110 //char c = 10000011(整型截斷) //以%d 打印,再次在內存中整型提升,再打印原碼 //int c = 11111111111111111111111110000011(補碼) //打印原碼:10000000000000000000000011111101 char c = a + b; printf("%d\n", c); return 0; }
如何整型提升:按照變量的數據類型的符號位來提升。
代碼示例2:
//負數的整型提升 char s1 = -1; 變量s1的二進制補碼中隻有8個比特位 11111111 因為char是有符號的,所以在整型提升的時候,高位補充符號位 即:11111111 11111111 11111111 11111111 //正數的整型提升 char s2 = 1; 變量s2的二進制補碼中隻有8個比特位 00000001 因為char是有符號的,所以在整型提升的時候,高位補充符號位 即:00000000 00000000 00000000 00000001
無符號數的整型提升,高位直接補0;
代碼示例3:
隱式轉換
int main() { int num = 5; printf("s1=%d\n", num / 2); printf("s2=%lf\n", num / 2.0); return 0; } s1=2 s2=2.500000 請按任意鍵繼續. . .
強制類型轉換
強制類型轉換指的是使用強制類型轉換運算符,將一個變量或表達式轉化成所需的類型
代碼示例1:
#include <stdio.h> int main() { float x = 0; int i = 0; x = 3.6f; i = x; //x為實型, i為整型,直接賦值會有警告 i = (int)x; //使用強制類型轉換 printf("x=%f, i=%d\n", x, i); return 0;
OK!!!觀眾老爺們,這裡隻是介紹瞭有關類型轉換的入門知識,如果朋友們覺得有一點點作用的話,希望朋友們能夠給予小菜鳥一點支持!後續繼續給朋友們帶來更好的博文,還希望朋友們能夠繼續關註,小菜鳥致力於把自己的學習經驗與個人理解更多的分享給大傢,望大傢喜歡與指正,請大傢以後多多支持WalkonNet!