C語言數(shù)據(jù)類型轉(zhuǎn)換實(shí)例代碼
數(shù)據(jù)類型轉(zhuǎn)換就是將數(shù)據(jù)(變量、表達(dá)式的結(jié)果)從一種類型轉(zhuǎn)換到另一種類型。例如,為了保存小數(shù)你可以將int類型的變量轉(zhuǎn)換為double類型。
數(shù)據(jù)類型轉(zhuǎn)換的一般格式為:
(type_name) expression
type_name為要轉(zhuǎn)換到的數(shù)據(jù)類型,expression為表達(dá)式。例如:
(float) a; //把a(bǔ)轉(zhuǎn)換為實(shí)型 (int)(x+y); //把x+y的結(jié)果轉(zhuǎn)換為整型 (float) 100; //將一個(gè)常量轉(zhuǎn)換為實(shí)型
【示例】將整數(shù)轉(zhuǎn)換為浮點(diǎn)數(shù):
#include <stdio.h> int main(){ int sum = 17, count = 5; double mean; mean = (double) sum / count; printf("Value of mean : %f\n", mean); return 0; }
運(yùn)行結(jié)果:
Value of mean : 3.400000
需要注意的是,類型轉(zhuǎn)換運(yùn)算符( )的優(yōu)先級(jí)高于/ ,(double) sum / count會(huì)先將 sum 轉(zhuǎn)換為 double 類型,然后再進(jìn)行除法運(yùn)算。如果寫作(double) (sum / count) ,那么運(yùn)行結(jié)果就是 3.000000。
這種由程序員顯式進(jìn)行的轉(zhuǎn)換稱為強(qiáng)制類型轉(zhuǎn)換。除了強(qiáng)制類型轉(zhuǎn)換,在不同數(shù)據(jù)類型的混合運(yùn)算中編譯器也會(huì)隱式地進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換,稱為自動(dòng)類型轉(zhuǎn)換。
自動(dòng)類型轉(zhuǎn)換遵循下面的規(guī)則:
1.若參與運(yùn)算的數(shù)據(jù)類型不同,則先轉(zhuǎn)換成同一類型,然后進(jìn)行運(yùn)算。
2.轉(zhuǎn)換按數(shù)據(jù)長(zhǎng)度增加的方向進(jìn)行,以保證精度不降低。例如int型和long型運(yùn)算時(shí),先把int量轉(zhuǎn)成long型后再進(jìn)行運(yùn)算。
3.所有的浮點(diǎn)運(yùn)算都是以雙精度進(jìn)行的,即使僅含float單精度量運(yùn)算的表達(dá)式,也要先轉(zhuǎn)換成double型,再作運(yùn)算。
4.char型和short型參與運(yùn)算時(shí),必須先轉(zhuǎn)換成int型。
5.在賦值運(yùn)算中,賦值號(hào)兩邊的數(shù)據(jù)類型不同時(shí),需要把右邊表達(dá)式的類型將轉(zhuǎn)換為左邊變量的類型。如果右邊表達(dá)式的數(shù)據(jù)類型長(zhǎng)度比左邊長(zhǎng)時(shí),將丟失一部分?jǐn)?shù)據(jù),這樣會(huì)降低精度。
下圖表示了類型自動(dòng)轉(zhuǎn)換的規(guī)則:
【示例】自動(dòng)數(shù)據(jù)類型轉(zhuǎn)換。
#include<stdio.h> int main(){ float PI=3.14159; int s1, r=5; double s2; s1 = r*r*PI; s2 = r*r*PI; printf("s1=%d, s2=%f\n", s1, s2); return 0; }
運(yùn)行結(jié)果:
s1=78, s2=78.539753
在計(jì)算表達(dá)式r*r*PI時(shí),r 和 PI 都轉(zhuǎn)換成double類型,表達(dá)式的結(jié)果也為double類型。但由于 s1 為整型,所以賦值運(yùn)算的結(jié)果仍為整型,舍去了小數(shù)部分。
注意是將小數(shù)部分直接丟掉,而不是按照四舍五入向前舍入。
無論是強(qiáng)制轉(zhuǎn)換或是自動(dòng)轉(zhuǎn)換,都只是為了本次運(yùn)算的需要而對(duì)變量的數(shù)據(jù)長(zhǎng)度進(jìn)行的臨時(shí)性轉(zhuǎn)換,而不改變數(shù)據(jù)說明時(shí)對(duì)該變量定義的類型。
請(qǐng)看下面的例子:
#include<stdio.h> int main(){ float f=5.75; printf("(int)f=%d, f=%f\n",(int)f, f); return 0; }
運(yùn)行結(jié)果:
(int)f=5, f=5.750000
以上就是對(duì) C語言數(shù)據(jù)類型的轉(zhuǎn)換的實(shí)例詳解,希望能幫助學(xué)習(xí) C語言基礎(chǔ)知識(shí)的同學(xué)。
相關(guān)文章
C語言函數(shù)傳遞數(shù)組和傳遞地址的區(qū)別你知道嗎
這篇文章主要介紹了C語言中數(shù)組作為函數(shù)的參數(shù)以及返回值的使用簡(jiǎn)單入門,這里以一維數(shù)組作為基本條件進(jìn)行例子講解,需要的朋友可以參考下2021-09-09c語言輸出字符串中最大對(duì)稱子串長(zhǎng)度的3種解決方案
這篇文章主要介紹了c語言輸出字符串中最大對(duì)稱子串長(zhǎng)度的3種解決方案,需要的朋友可以參考下2014-03-03使用VScode搭建ROS開發(fā)環(huán)境的教程詳解
這篇文章主要介紹了使用VScode搭建ROS開發(fā)環(huán)境,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08C語言數(shù)據(jù)結(jié)構(gòu)超詳細(xì)講解單向鏈表
鏈表可以說是一種最為基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)了,而單向鏈表更是基礎(chǔ)中的基礎(chǔ)。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護(hù)一組數(shù)據(jù)集合時(shí),就可以使用鏈表,這一點(diǎn)和數(shù)組很相似2022-03-03c語言合并兩個(gè)已排序數(shù)組的示例(c語言數(shù)組排序)
如何將兩個(gè)已排序數(shù)組合并成一個(gè)排序數(shù)組,下面我們給出使用c語言合并兩個(gè)已排序數(shù)組的示例,需要的朋友可以參考下2014-03-03C++20 特性 協(xié)程 Coroutines(1)
這篇文章主要給大家分享得是C++20 得特性 協(xié)程 Coroutines,下面文章內(nèi)容我們將來具體介紹什么是協(xié)程,協(xié)程得好處等知識(shí)點(diǎn),需要的朋友可以參考一下2021-10-10