欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言數(shù)據(jù)類型轉(zhuǎn)換實(shí)例代碼

 更新時(shí)間:2016年07月19日 17:55:32   投稿:lqh  
本文主要介紹C 語言數(shù)據(jù)類型轉(zhuǎn)換,這里通過代碼實(shí)例進(jìn)行詳解,這是C語言基礎(chǔ)部分,需要的朋友可以參考下

數(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)先級高于/ (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ù)長度增加的方向進(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)算中,賦值號兩邊的數(shù)據(jù)類型不同時(shí),需要把右邊表達(dá)式的類型將轉(zhuǎn)換為左邊變量的類型。如果右邊表達(dá)式的數(shù)據(jù)類型長度比左邊長時(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)算的需要而對變量的數(shù)據(jù)長度進(jìn)行的臨時(shí)性轉(zhuǎn)換,而不改變數(shù)據(jù)說明時(shí)對該變量定義的類型。

請看下面的例子:

#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

以上就是對 C語言數(shù)據(jù)類型的轉(zhuǎn)換的實(shí)例詳解,希望能幫助學(xué)習(xí) C語言基礎(chǔ)知識(shí)的同學(xué)。

相關(guān)文章

  • C語言堆結(jié)構(gòu)處理TopK問題詳解

    C語言堆結(jié)構(gòu)處理TopK問題詳解

    TopK問題即在N個(gè)數(shù)中找出最大的前K個(gè),這篇文章將詳細(xì)講解如何利用小根堆的方法解決TopK問題,文中代碼具有一定參考價(jià)值,快跟隨小編一起學(xué)習(xí)一下吧
    2022-06-06
  • C語言函數(shù)傳遞數(shù)組和傳遞地址的區(qū)別你知道嗎

    C語言函數(shù)傳遞數(shù)組和傳遞地址的區(qū)別你知道嗎

    這篇文章主要介紹了C語言中數(shù)組作為函數(shù)的參數(shù)以及返回值的使用簡單入門,這里以一維數(shù)組作為基本條件進(jìn)行例子講解,需要的朋友可以參考下
    2021-09-09
  • C語言代碼實(shí)現(xiàn)猜數(shù)字

    C語言代碼實(shí)現(xiàn)猜數(shù)字

    這篇文章主要為大家詳細(xì)介紹了C語言代碼實(shí)現(xiàn)猜數(shù)字,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • c語言輸出字符串中最大對稱子串長度的3種解決方案

    c語言輸出字符串中最大對稱子串長度的3種解決方案

    這篇文章主要介紹了c語言輸出字符串中最大對稱子串長度的3種解決方案,需要的朋友可以參考下
    2014-03-03
  • 使用VScode搭建ROS開發(fā)環(huán)境的教程詳解

    使用VScode搭建ROS開發(fā)環(huán)境的教程詳解

    這篇文章主要介紹了使用VScode搭建ROS開發(fā)環(huán)境,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • C語言數(shù)據(jù)結(jié)構(gòu)超詳細(xì)講解單向鏈表

    C語言數(shù)據(jù)結(jié)構(gòu)超詳細(xì)講解單向鏈表

    鏈表可以說是一種最為基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)了,而單向鏈表更是基礎(chǔ)中的基礎(chǔ)。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護(hù)一組數(shù)據(jù)集合時(shí),就可以使用鏈表,這一點(diǎn)和數(shù)組很相似
    2022-03-03
  • c語言合并兩個(gè)已排序數(shù)組的示例(c語言數(shù)組排序)

    c語言合并兩個(gè)已排序數(shù)組的示例(c語言數(shù)組排序)

    如何將兩個(gè)已排序數(shù)組合并成一個(gè)排序數(shù)組,下面我們給出使用c語言合并兩個(gè)已排序數(shù)組的示例,需要的朋友可以參考下
    2014-03-03
  • 詳細(xì)聊一聊algorithm中的排序算法

    詳細(xì)聊一聊algorithm中的排序算法

    <algorithm>是C++標(biāo)準(zhǔn)程序庫中的一個(gè)頭文件,定義了C++?STL標(biāo)準(zhǔn)中的基礎(chǔ)性的算法(均為函數(shù)模板),下面這篇文章主要給大家介紹了關(guān)于algorithm中排序算法的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • C++20 特性 協(xié)程 Coroutines(1)

    C++20 特性 協(xié)程 Coroutines(1)

    這篇文章主要給大家分享得是C++20 得特性 協(xié)程 Coroutines,下面文章內(nèi)容我們將來具體介紹什么是協(xié)程,協(xié)程得好處等知識(shí)點(diǎn),需要的朋友可以參考一下
    2021-10-10
  • OpenCV實(shí)現(xiàn)圖像腐蝕

    OpenCV實(shí)現(xiàn)圖像腐蝕

    這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)圖像腐蝕,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評論