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!

推薦閱讀: