詳解C語(yǔ)言基礎(chǔ)的類型轉(zhuǎn)換
類型轉(zhuǎn)換
數(shù)據(jù)有不同的類型,不同類型數(shù)據(jù)之間進(jìn)行混合運(yùn)算時(shí)必然涉及到類型的轉(zhuǎn)換問(wèn)題。轉(zhuǎn)換包括隱式類型轉(zhuǎn)換和強(qiáng)制類型轉(zhuǎn)換。
類型轉(zhuǎn)換的原則:占用內(nèi)存字節(jié)數(shù)少(值域小)的類型,向占用內(nèi)存字節(jié)數(shù)多(值域大)的類型轉(zhuǎn)換,以保證精度不降低。

隱式類型轉(zhuǎn)換
隱式轉(zhuǎn)換也稱為自動(dòng)轉(zhuǎn)換,遵循一定的規(guī)則,由編譯器自動(dòng)完成。
C的整型算數(shù)運(yùn)算總是至少以缺省整型類型的精度來(lái)進(jìn)行,為了獲得這個(gè)精度,表達(dá)式中的字符和短整形操作數(shù)在使用之前都被轉(zhuǎn)換成普通整型,這種轉(zhuǎn)換為整型提升。
整型提升:通用CPU是難以直接實(shí)現(xiàn)兩個(gè)8比特位直接相加運(yùn)算。所以表達(dá)式中各種長(zhǎng)度可能小于int長(zhǎng)度的整型值,都必須轉(zhuǎn)換為int或者unsigned int ,然后才能送入CPU去執(zhí)行運(yùn)算。
代碼示例1:
int main()
{
char a = 5, b = 126;
//5:00000000 00000000 00000000 00000101
//a:0000 0101(截?cái)嗖僮?
//126:00000000 00000000 00000000 01111110
//b:0111 1110
//當(dāng)a和b相加時(shí),都是char類型,就會(huì)發(fā)生整型提升
//int c = 000000000000000000000000 00000101 + 000000000000000000000000 01111110
//char c = 10000011(整型截?cái)?
//以%d 打印,再次在內(nèi)存中整型提升,再打印原碼
//int c = 11111111111111111111111110000011(補(bǔ)碼)
//打印原碼:10000000000000000000000011111101
char c = a + b;
printf("%d\n", c);
return 0;
}

如何整型提升:按照變量的數(shù)據(jù)類型的符號(hào)位來(lái)提升。
代碼示例2:
//負(fù)數(shù)的整型提升 char s1 = -1; 變量s1的二進(jìn)制補(bǔ)碼中只有8個(gè)比特位 11111111 因?yàn)閏har是有符號(hào)的,所以在整型提升的時(shí)候,高位補(bǔ)充符號(hào)位 即:11111111 11111111 11111111 11111111 //正數(shù)的整型提升 char s2 = 1; 變量s2的二進(jìn)制補(bǔ)碼中只有8個(gè)比特位 00000001 因?yàn)閏har是有符號(hào)的,所以在整型提升的時(shí)候,高位補(bǔ)充符號(hào)位 即:00000000 00000000 00000000 00000001
無(wú)符號(hào)數(shù)的整型提升,高位直接補(bǔ)0;
代碼示例3:
隱式轉(zhuǎn)換
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
請(qǐng)按任意鍵繼續(xù). . .
強(qiáng)制類型轉(zhuǎn)換
強(qiáng)制類型轉(zhuǎn)換指的是使用強(qiáng)制類型轉(zhuǎn)換運(yùn)算符,將一個(gè)變量或表達(dá)式轉(zhuǎn)化成所需的類型
代碼示例1:
#include <stdio.h>
int main()
{
float x = 0;
int i = 0;
x = 3.6f;
i = x; //x為實(shí)型, i為整型,直接賦值會(huì)有警告
i = (int)x; //使用強(qiáng)制類型轉(zhuǎn)換
printf("x=%f, i=%d\n", x, i);
return 0;
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
- 詳解C語(yǔ)言中不同類型的數(shù)據(jù)轉(zhuǎn)換規(guī)則
- C語(yǔ)言數(shù)據(jù)類型轉(zhuǎn)換實(shí)例代碼
- C語(yǔ)言強(qiáng)制類型轉(zhuǎn)換規(guī)則實(shí)例詳解
- 淺談c語(yǔ)言中類型隱性轉(zhuǎn)換的坑
- C語(yǔ)言中強(qiáng)制類型轉(zhuǎn)換的常見(jiàn)方法
- C語(yǔ)言類型轉(zhuǎn)換與常量的細(xì)節(jié)深入理解探究
- C語(yǔ)言簡(jiǎn)明講解類型轉(zhuǎn)換的使用與作用
- C語(yǔ)言中的數(shù)據(jù)類型強(qiáng)制轉(zhuǎn)換
- C語(yǔ)言中類型轉(zhuǎn)換不匹配的解決方案
相關(guān)文章
Ubuntu中使用VS Code與安裝C/C++插件的教程詳解
這篇文章主要介紹了Ubuntu中使用VS Code與安裝C/C++插件的教程詳解,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
C語(yǔ)言中自動(dòng)與強(qiáng)制轉(zhuǎn)換全解析
在編寫(xiě)C程序時(shí),類型轉(zhuǎn)換是確保數(shù)據(jù)正確性和一致性的關(guān)鍵環(huán)節(jié),無(wú)論是隱式轉(zhuǎn)換還是顯式轉(zhuǎn)換,都各有特點(diǎn)和應(yīng)用場(chǎng)景,本文將詳細(xì)探討C語(yǔ)言中的類型轉(zhuǎn)換機(jī)制,幫助您更好地理解并在實(shí)際編碼中靈活運(yùn)用這些知識(shí),需要的朋友可以參考下2025-02-02
C語(yǔ)言算法練習(xí)之求二維數(shù)組最值問(wèn)題
這篇文章主要為大家介紹了C語(yǔ)言算法練習(xí)中求二維數(shù)組最值的實(shí)現(xiàn)方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C語(yǔ)言有一定幫助,需要的可以參考一下2022-09-09
C語(yǔ)言調(diào)用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)增刪改查
SQLite是一種輕量級(jí)的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),是一個(gè)開(kāi)源的、零配置的、服務(wù)器端的、自包含的、零管理的、事務(wù)性的SQL數(shù)據(jù)庫(kù)引擎,本文主要介紹了如何調(diào)用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)增刪改查,需要的可以參考一下2023-08-08
C++ 先對(duì)數(shù)組排序,在進(jìn)行折半查找
以下小編就為大家介紹兩種實(shí)現(xiàn)方法。第一種方法是,選擇排序法+循環(huán)折半查找法。第二種方法是,冒泡排序法+遞歸折半查找法。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-10-10
C++中priority_queue模擬實(shí)現(xiàn)的代碼示例
在c++語(yǔ)言中數(shù)據(jù)結(jié)構(gòu)中的堆結(jié)構(gòu)可以通過(guò)STL庫(kù)中的priority_queue 優(yōu)先隊(duì)列來(lái)實(shí)現(xiàn),這樣做極大地簡(jiǎn)化了我們的工作量,這篇文章主要給大家介紹了關(guān)于C++中priority_queue模擬實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2021-08-08

