C語言有以下幾種取整方法:
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作與策劃設(shè)計(jì),方正網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:方正等地區(qū)。方正做網(wǎng)站價(jià)格咨詢:18980820575
1、直接賦值給整數(shù)變量。如:
int i = 2.5; 或 i = (int) 2.5;
這種方法采用的是舍去小數(shù)部分,能用于你的問題。
2、C/C++中的整數(shù)除法運(yùn)算符“/”本身就有取整功能(int / int),而下面介紹的取整函數(shù)返回值是double。整數(shù)除法對(duì)正數(shù)的取整是舍去小數(shù)部分,能用于你的問題。不過整數(shù)除法對(duì)負(fù)數(shù)的取整結(jié)果和使用的C編譯器有關(guān)。
3、使用floor函數(shù)。floor(x)返回的是小于或等于x的最大整數(shù)。如:
floor(2.5) = 2
floor(-2.5) = -3
4、使用ceil函數(shù)。ceil(x)返回的是大于x的最小整數(shù)。如:
ceil(2.5) = 3
ceil(-2.5) = -2
floor()是向負(fù)無窮大舍入,floor(-2.5) = -3;ceil()是向正無窮大舍入,ceil(-2.5) = -2。floor函數(shù)能用于你的問題。
5、
int b = (int)a;//取整
int c = (int)(a+0.5);//四舍五入
在公司項(xiàng)目中看到關(guān)于錢的數(shù)據(jù)在接口展示、添加修改的各種情況下結(jié)構(gòu)體中相應(yīng)字段用的都是string類型。覺得不太合理,因此查閱了一些資料,整理如下。
在網(wǎng)上搜到一篇博客:
在程序計(jì)算中涉及到錢的時(shí)候,為什么要用Decimal而不是Float
博客中介紹,如果用float類型再轉(zhuǎn)為decimal類型時(shí)會(huì)造成精度丟失。轉(zhuǎn)為string后再轉(zhuǎn)為decimal則可以解決問題,保證精度??粗孟袷呛芡昝赖幕卮鹆宋蚁胍私獾膯栴},但仔細(xì)一看用的語言是python,于是我便親自試了下:
結(jié)果確實(shí)如此,但看版本是2.7,我懷疑是不是python2.7版本落后,因此存在問題,于是又換了python3,再次測(cè)試:
結(jié)論依然是一樣。好吧,證實(shí)了,對(duì)于python確實(shí)應(yīng)該先轉(zhuǎn)為string再轉(zhuǎn)為decimal。
但是,python是這樣,難道go也是這樣嗎,于是我又開始了進(jìn)一步測(cè)試:
go中decimal使用第三方庫
這里是直接用float64轉(zhuǎn)為decimal,并沒有通過string中轉(zhuǎn),結(jié)果輸出如下:
乍一看,看著好像是精度丟失了似的,但是對(duì)比后我們發(fā)現(xiàn),float64和decimal前后都是一致的,也就是說float64轉(zhuǎn)為decimal之后,保持了原樣。那些看起來小數(shù)點(diǎn)后位數(shù)很多的結(jié)果,是因?yàn)閒loat64浮點(diǎn)類型計(jì)算產(chǎn)生的問題,跟轉(zhuǎn)換并沒有關(guān)系。
為了驗(yàn)證這一結(jié)論,我又寫了下面的測(cè)試:
不使用浮點(diǎn)類型相加,而用decimal類型相加,這樣輸出結(jié)果果然沒問題了:
因此我們可以得出結(jié)論:對(duì)于go語言,在把float轉(zhuǎn)換為decimal類型時(shí),并不需要像python一樣通過string中轉(zhuǎn),也依然可以保持精度。進(jìn)一步,我們也可以想到上面的問題,對(duì)于錢,在結(jié)構(gòu)體字段中,我們完全可以直接使用float類型,并不需要用string類型。而且好處時(shí),使用float數(shù)值類型,無論對(duì)于前端還是后端,在進(jìn)行數(shù)值范圍驗(yàn)證的時(shí)候,會(huì)更方便,不必把string轉(zhuǎn)為float后再驗(yàn)證了。
上面提到了decimal包,我們這里簡(jiǎn)單看下,里面的常用的方法:
定義decimal的幾種方式:
decimal數(shù)值運(yùn)算
比較:
我們?cè)倏聪赂↑c(diǎn)精度運(yùn)算不準(zhǔn)確的原因,這篇文章講解的比較細(xì)
浮點(diǎn)精度(float、double)運(yùn)算不精確的原因
精度運(yùn)算不準(zhǔn)確這是為什么呢?我們接下來就需要從計(jì)算機(jī)所有數(shù)據(jù)的表現(xiàn)形式二進(jìn)制說起了。如果大家很了解二進(jìn)制與十進(jìn)制的相互轉(zhuǎn)換,那么就能輕易的知道精度運(yùn)算不準(zhǔn)確的問題原因是什么了。
接下來我們看一個(gè)簡(jiǎn)單的例子 2.1 這個(gè)十進(jìn)制數(shù)轉(zhuǎn)成二進(jìn)制是什么樣子的。
落入無限循環(huán)結(jié)果為 10.0001100110011........ , 我們的計(jì)算機(jī)在存儲(chǔ)小數(shù)時(shí)肯定是有長(zhǎng)度限制的,所以會(huì)進(jìn)行截取部分小數(shù)進(jìn)行存儲(chǔ),從而導(dǎo)致計(jì)算機(jī)存儲(chǔ)的數(shù)值只能是個(gè)大概的值,而不是精確的值。從這里看出來我們的計(jì)算機(jī)根本就無法使用二進(jìn)制來精確的表示 2.1 這個(gè)十進(jìn)制數(shù)字的值,連表示都無法精確表示出來,計(jì)算肯定是會(huì)出現(xiàn)問題的。
1、為什么數(shù)值表示用decimal 不用double
2、在程序計(jì)算中涉及到錢的時(shí)候,為什么要用Decimal而不是Float
3、MySQL數(shù)據(jù)類型DECIMAL用法
4、浮點(diǎn)精度(float、double)運(yùn)算不精確的原因
C語言中,浮點(diǎn)型轉(zhuǎn)換為整型可以用:強(qiáng)制類型轉(zhuǎn)換、自動(dòng)類型轉(zhuǎn)換,例如:(int)3.14、int a = 3.14。
1、強(qiáng)制類型轉(zhuǎn)換
強(qiáng)制類型轉(zhuǎn)換是通過類型轉(zhuǎn)換運(yùn)算來實(shí)現(xiàn)的。其一般形式為:(類型說明符)(表達(dá)式),其功能是把表達(dá)式的運(yùn)算結(jié)果強(qiáng)制轉(zhuǎn)換成類型說明符所表示的類型。
例如: (double) a 把a(bǔ)轉(zhuǎn)換為雙精度浮點(diǎn)型,(int)(x+y) 把x+y的結(jié)果轉(zhuǎn)換為整型。
2、自動(dòng)類型轉(zhuǎn)換
(1)執(zhí)行算術(shù)運(yùn)算時(shí),低類型(短字節(jié))可以轉(zhuǎn)換為高類型(長(zhǎng)字節(jié));例如: int型轉(zhuǎn)換成double型,char型轉(zhuǎn)換成int型等。
(2)賦值表達(dá)式中,等號(hào)右邊表達(dá)式的值的類型自動(dòng)隱式地轉(zhuǎn)換為左邊變量的類型,并賦值給它。
(3)函數(shù)調(diào)用時(shí),將實(shí)參的值傳遞給形參,系統(tǒng)首先會(huì)自動(dòng)隱式地把實(shí)參的值的類型轉(zhuǎn)換為形參的類型,然后再賦值給形參。
(4)函數(shù)有返回值時(shí),系統(tǒng)首先會(huì)自動(dòng)隱式地將返回表達(dá)式的值的類型轉(zhuǎn)換為函數(shù)的返回類型,然后再賦值給調(diào)用函數(shù)返回。
擴(kuò)展資料:
C語言中常用的數(shù)據(jù)類型:
1、int:整型
2、float:?jiǎn)尉雀↑c(diǎn)型
3、double:雙精度浮點(diǎn)型
4、char:字符型
5、char *:字符指針型
參考資料來源:百度百科-強(qiáng)制類型轉(zhuǎn)換
浮點(diǎn)型強(qiáng)轉(zhuǎn)整形會(huì)丟失精度,也就是小數(shù)后面的數(shù)會(huì)截掉,比如變量i時(shí)浮點(diǎn)型要轉(zhuǎn)換為整形時(shí),在變量i前面加個(gè)括號(hào),括號(hào)里面寫上你想轉(zhuǎn)的類型
(int)i
位運(yùn)算符 只用于 整型。float 要轉(zhuǎn)為 整型, 否則 編譯 不能通過。 int x=2,z; float y = 2.0; z = x (int) y; // 這樣才能通過編譯。不會(huì)自動(dòng)轉(zhuǎn)換。否則有“illegal“ 操作數(shù)錯(cuò)誤。 printf("%x",z);