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

C語(yǔ)言強(qiáng)制類型轉(zhuǎn)換規(guī)則實(shí)例詳解

 更新時(shí)間:2022年06月02日 10:34:28   作者:qq_43133135  
強(qiáng)制類型轉(zhuǎn)換是把變量從一種類型轉(zhuǎn)換為另一種數(shù)據(jù)類型,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言強(qiáng)制類型轉(zhuǎn)換的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

整形之間的強(qiáng)制轉(zhuǎn)換

在強(qiáng)制類型轉(zhuǎn)換中,我們常用的整形強(qiáng)制轉(zhuǎn)換有無(wú)符號(hào)和有符號(hào)類型的強(qiáng)制轉(zhuǎn)換。所以首先我們得介紹一下計(jì)算機(jī)中存儲(chǔ)數(shù)字的方式,計(jì)算機(jī)中通常以補(bǔ)碼的形式來(lái)存儲(chǔ)數(shù)據(jù),以8位數(shù)據(jù)為例,二進(jìn)制與有符號(hào)數(shù)的對(duì)應(yīng)關(guān)系為:

012127-128-127-1
0000 00000000 00010000 00100111 11111000 00001000 00011111 1111

無(wú)符號(hào)轉(zhuǎn)有符號(hào)

012127128129255
0000 00000000 00010000 00100111 11111000 00001000 00011111 1111

所以對(duì)于有符號(hào)數(shù),首先最高位是正負(fù)的標(biāo)志位。要將無(wú)符號(hào)數(shù)強(qiáng)制轉(zhuǎn)化為有符號(hào)數(shù)時(shí),其內(nèi)存上的二進(jìn)制是不會(huì)改變的,只是我們對(duì)它的解釋變了,即無(wú)符號(hào)數(shù)128強(qiáng)制轉(zhuǎn)化有符號(hào)數(shù)即-128。

當(dāng)然這樣引申出來(lái)的一種好處就是對(duì)于有符號(hào)數(shù)的判斷,如

char a;
...
if((a>=0)&&(a<80))
{
....
}

可以使用強(qiáng)制轉(zhuǎn)化,省去一個(gè)判斷條件

char a;
...
if( ((unsigned char)a) < 80)
{
....
}

有符號(hào)轉(zhuǎn)無(wú)符號(hào)

將有符號(hào)數(shù)變成無(wú)符號(hào)數(shù)時(shí),情況也類似,如8位的有符號(hào)數(shù)120轉(zhuǎn)無(wú)符號(hào)也是120,但8位的-1轉(zhuǎn)無(wú)符號(hào)則為255。所以當(dāng)我們?cè)谟蟹?hào)數(shù)的計(jì)算中,想保留大于等于0的數(shù),不能通過(guò)強(qiáng)制轉(zhuǎn)化來(lái)完成,必須得加判斷:

char a,b,d;
unsigned char c;
....
c=(unsigned char)(a+b);  (×):當(dāng)運(yùn)算結(jié)果小于0時(shí)c會(huì)異常,變成超級(jí)大數(shù)

d=a+b;
c = (d<0)?0:d;           (√)

不同長(zhǎng)度數(shù)字轉(zhuǎn)化中的截?cái)?/h3>

比如我有一個(gè)8位的有符號(hào)數(shù)-1,要轉(zhuǎn)換為一個(gè)16位的有符號(hào)數(shù),那么結(jié)果仍舊是-1。首先我們要明確一點(diǎn),那就是雖然8位的有符號(hào)數(shù)-1的二進(jìn)制原本1111 1111,但載入32位的cpu中運(yùn)算時(shí),它將轉(zhuǎn)化為32位的有符號(hào)數(shù)進(jìn)行運(yùn)算,即int類型的-1。所以對(duì)于char類型的數(shù)據(jù),即使運(yùn)算結(jié)果超過(guò)了該類型,其實(shí)也不會(huì)發(fā)生異常:

char a=127,b=127,c=127,e;
int d;
....
e=a+b+c;   	 (×):當(dāng)運(yùn)算結(jié)果超過(guò)存儲(chǔ)類型的表示范圍時(shí),會(huì)因截?cái)喈a(chǎn)生錯(cuò)誤
d=a+b+c;     (√):32位的int類型足夠存儲(chǔ)結(jié)果。

所以我們?nèi)绻巡煌L(zhǎng)度的數(shù)字進(jìn)行類型轉(zhuǎn)換,只有兩個(gè)步驟:

1、將該數(shù)表示為32位
2、將32位數(shù)截?cái)酁榻Y(jié)果類型

不過(guò),可以確定的一點(diǎn)就是,進(jìn)行第一步時(shí),數(shù)的值不會(huì)發(fā)生變化:

比如8位有符號(hào)數(shù)-1(1111 1111)將轉(zhuǎn)化為32位的-1(1111 1111 1111 1111 … 1111 111)。
而8位的無(wú)符號(hào)數(shù)255(1111 1111)轉(zhuǎn)為32位時(shí),也仍舊是255:(0000 0000…0000 0000 1111 111)。

但進(jìn)行第二步轉(zhuǎn)換時(shí),值會(huì)由于截?cái)喽l(fā)生變化,而這個(gè)截?cái)嘁话闶歉呶唤財(cái)啵ㄉ釛壐呶?,保留低位)?/p>

如int類型的255(0000 0000 … 0000 0000 1111 1111)轉(zhuǎn)化為8為的unsigned char類型時(shí),前面的0將被截?cái)?,只保留?位,即255(1111 1111),當(dāng)然,若是轉(zhuǎn)為8為的有符號(hào)char類型,則為-1(1111 1111)。截?cái)嗍嵌M(jìn)制層面的位數(shù)截?cái)?,與實(shí)際值無(wú)關(guān)。

整形與浮點(diǎn)數(shù)的強(qiáng)制類型轉(zhuǎn)換

我們都知道浮點(diǎn)數(shù)float類型一般遵循ieee754標(biāo)準(zhǔn),有符號(hào)位,階碼和尾數(shù):

與整形相同,符號(hào)位是1時(shí)代表負(fù)數(shù),是0則為正數(shù)。而階碼代表小數(shù)點(diǎn)在哪兒,類似于科學(xué)計(jì)數(shù)法100會(huì)被表示為 1.0 × 10^2。詳細(xì)的這里不介紹了,我們重點(diǎn)放在強(qiáng)制轉(zhuǎn)化上:

對(duì)于一個(gè)int類型的數(shù),只要在浮點(diǎn)數(shù)的表示范圍內(nèi),便可以正確的轉(zhuǎn)為浮點(diǎn)數(shù)格式。

但是對(duì)于一個(gè)浮點(diǎn)類型的數(shù),在轉(zhuǎn)化為整形時(shí),則會(huì)只保留整數(shù)位,如:

int a= (int)0.1;    即a=0
int a= (int)1.1;    即a=1
int a= (int)1.5;    即a=1
int a= (int)-1.5;   即a=-1

所以如果要四舍五入之類的的,則不能靠強(qiáng)制轉(zhuǎn)換,得用相關(guān)的函數(shù)。當(dāng)然若是轉(zhuǎn)為其他整形,則結(jié)果將有32位的整形結(jié)果進(jìn)行截?cái)嗟玫健?/p>

當(dāng)然,強(qiáng)制轉(zhuǎn)換和 floor 這個(gè)函數(shù)的功能其實(shí)很像,floor函數(shù)的功能是向下取整:

int a= floorf(0.1);    即a=0
int a= floorf(1.1);    即a=1
int a= floorf(1.5);    即a=1

對(duì)于大于0的浮點(diǎn)數(shù),他倆其實(shí)可以替換,而當(dāng)小于0時(shí),他倆區(qū)別很大:

int a= floorf(-0.1);    即a=-1
int a= floorf(-1.1);    即a=-2

int a=(int)-0.1;        即a=0
int a=(int)-1.1;        即a=-1

強(qiáng)制轉(zhuǎn)化的結(jié)果,會(huì)產(chǎn)生正負(fù)0這種概念,如-0.9到0.9強(qiáng)制轉(zhuǎn)化結(jié)果都為0。使用強(qiáng)制轉(zhuǎn)化時(shí)會(huì)產(chǎn)生越界輸出

總結(jié)

到此這篇關(guān)于C語(yǔ)言強(qiáng)制類型轉(zhuǎn)換規(guī)則的文章就介紹到這了,更多相關(guān)C語(yǔ)言強(qiáng)制類型轉(zhuǎn)換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)彈跳小球項(xiàng)目

    C語(yǔ)言實(shí)現(xiàn)彈跳小球項(xiàng)目

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)彈跳小球項(xiàng)目,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • c++核心編程之函數(shù)的重載

    c++核心編程之函數(shù)的重載

    這篇文章主要介紹了c++核心編程之函數(shù)的重載,函數(shù)可以重復(fù)使用,提高了復(fù)用性,但前提是必須在一個(gè)作用域并且函數(shù)名稱相同,下面附代碼詳細(xì)介紹,需要的小伙伴可以參考一下
    2022-03-03
  • C++合并二叉樹的思路與示例代碼

    C++合并二叉樹的思路與示例代碼

    二叉樹大家應(yīng)該都不陌生,但是合并二叉樹呢?這篇文章主要給大家介紹了關(guān)于C++合并二叉樹的相關(guān)資料,文中給出了兩種解決的方法,大家可以根據(jù)需要選擇對(duì)應(yīng)的方法,需要的朋友可以參考下
    2021-08-08
  • C++中replace()?函數(shù)的基本用法

    C++中replace()?函數(shù)的基本用法

    今天就跟大家聊聊有關(guān)C++中replace()函數(shù)的作用是什么,可能很多人都不太了解,為了讓大家更加了解,這篇文章主要給大家介紹了關(guān)于C++中replace()?函數(shù)的基本用法,需要的朋友可以參考下
    2021-11-11
  • C++設(shè)計(jì)模式之觀察者模式

    C++設(shè)計(jì)模式之觀察者模式

    這篇文章主要介紹了C++設(shè)計(jì)模式之觀察者模式,本文講解了什么是觀察者模式、觀察者模式的UML類圖、觀察者模式的使用場(chǎng)合等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • C++實(shí)現(xiàn)LeetCode(112.二叉樹的路徑和)

    C++實(shí)現(xiàn)LeetCode(112.二叉樹的路徑和)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(112.二叉樹的路徑和),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 詳解C++設(shè)計(jì)模式編程中對(duì)狀態(tài)模式的運(yùn)用

    詳解C++設(shè)計(jì)模式編程中對(duì)狀態(tài)模式的運(yùn)用

    這篇文章主要介紹了C++設(shè)計(jì)模式編程中對(duì)狀態(tài)模式的運(yùn)用,狀態(tài)模式允許一個(gè)對(duì)象在其內(nèi)部狀態(tài)改變時(shí)改變它的行為,對(duì)象看起來(lái)似乎修改了它的類,需要的朋友可以參考下
    2016-03-03
  • C++常用的#include頭文件總結(jié)

    C++常用的#include頭文件總結(jié)

    這篇文章主要介紹了C++常用的#include頭文件,對(duì)初學(xué)者理解C++程序設(shè)計(jì)大有好處的相關(guān)資料
    2014-07-07
  • C語(yǔ)言?動(dòng)態(tài)內(nèi)存管理全面解析

    C語(yǔ)言?動(dòng)態(tài)內(nèi)存管理全面解析

    動(dòng)態(tài)內(nèi)存是相對(duì)靜態(tài)內(nèi)存而言的。所謂動(dòng)態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動(dòng)態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存,本文帶你深入探究C語(yǔ)言中動(dòng)態(tài)內(nèi)存的管理
    2022-02-02
  • C++單例模式為何要實(shí)例化一個(gè)對(duì)象不全部使用static

    C++單例模式為何要實(shí)例化一個(gè)對(duì)象不全部使用static

    這篇文章主要介紹了C++單例模式為何要實(shí)例化一個(gè)對(duì)象不全部使用static,文基于C++圍繞主題展開詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-05-05

最新評(píng)論