国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

基于C++浮點數(float、double)類型數據比較與轉換的詳解

2020-01-26 16:12:22
字體:
來源:轉載
供稿:網友
浮點數在內存中的存儲機制和整型數不同,其有舍入誤差,在計算機中用近似表示任意某個實數。具體的說,這個實數由一個整數或定點數(即尾數)乘以某個基數(計算機中通常是2)的整數次冪得到,這種表示方法類似于基數為10的科學記數法。
所以浮點數在運算過程中通常伴隨著因為無法精確表示而進行的近似或舍入。但是這種設計的好處是可以在固定的長度上存儲更大范圍的數。
1、將字符串轉換為float、double過程存在精度損失,只是float、double各自損失的精度不相同而已
std::string str="8.2";
float cc=atof(str.c_str());  //cc的值為8.1999998
std::string str="8.2";
double cc=atof(str.c_str());  //cc的值為8.1999999999999993
2、將float、double轉換為字符過程中可能存在精度損失,但是通過%.8lf可以規避
(1)float小數點前后加起來有效數字只有6位。當給定的float有效數在6位以內轉換為字符不會丟失精度,當有效位數大于6位就會存在精度丟失
//精度沒有丟失
char buf[100]={'/0'};
float aa=8000.25;
sprintf(buf,"%f",aa);   //8000.250000
//精度沒有丟失
char buf[100]={'/0'};
float aa=8.00025;
sprintf(buf,"%f",aa);   buf = 8.000250
//精度丟失,存在誤差
char buf[100]={'/0'};
float aa=8000.251;
sprintf(buf,"%f",aa);  //8000.250977
//精度丟失,存在誤差此時使用.8lf也無效
char buf[100]={'/0'};
float aa=8000.251;
sprintf(buf,"%.8lf",aa); //8000.25097656
(2)double小數前后加起來的有效數字只有16位,當給定的double有效數在16位以內轉換為字符串不會丟失精度,當有效位數大于16位湖影公寓存在精度丟失
存在誤差
char buf[100]={'/0'};
double aa=121.437565871234012;
sprintf(buf,"%.20lf",aa); //121.43756587123401000000
//沒有誤差
char buf[100]={'/0'};
double aa=8000.256165;
sprintf(buf,"%.8lf",aa);
std::cout <<buf<<std::endl; //8000.25616500
3、浮點數比較
用"=="來比較兩個double應該相等的類型,返回真值完全是不確定的。計算機對浮點數的進行計算的原理是只保證必要精度內正確即可。
我們在判斷浮點數相等時,推薦用范圍來確定,若x在某一范圍內,我們就認為相等,至于范圍怎么定義,要看實際情況而已了,float,和double 各有不同
所以const float EPSINON = 0.00001;
if ((x >= - EPSINON) && (x <= EPSINON) 這樣判斷是可取的
至于為什么取0.00001,可以自己按實際情況定義
根據上面分析建議在系統開發過程中設計到字符轉換建議采用double類型,精度設置為%.8lf即可,在比較浮點數十建議EPSINON = 0.00000001
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 九江市| 河源市| 威宁| 枣强县| 达日县| 外汇| 招远市| 安国市| 黄梅县| 恩施市| 平利县| 临夏市| 贡嘎县| 阜康市| 新宾| 扬州市| 和田市| 江永县| 绍兴县| 淳化县| 奉化市| 安西县| 阜新市| 云龙县| 泸水县| 泸州市| 禄丰县| 岳阳县| 拉萨市| 临武县| 炎陵县| 罗山县| 洞头县| 壶关县| 芒康县| 玉屏| 玛曲县| 正宁县| 景东| 天津市| 霍林郭勒市|