程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> 講述C++對浮點數的格式化顯示

講述C++對浮點數的格式化顯示

編輯:C++入門知識

下面進行詳細說明在C++中怎樣對程序中的浮點數據進行“整齊”地格式化呢?在此我們有一個迂回的方法,先把它們轉換為字符串,格式化後以文本形式顯示出來,我相信這都是一些技術人員的頭疼的問題。

如有C++中有一個函數,其可接受一個long double參數,並將參數轉換為字符串,結果字符串應保留兩位小數,例如,浮點值123.45678應該生成“123.45”這樣的字符串。表面上看來這是一個意義不大的編程問題,然而,如果真要在實際中派上用場,函數應設計為具有一定彈性,以允許調用者指定小數位數。另外,函數也應該能夠處理各種異常情況,如像123.0或123這樣的整數。

在開始之前,先看一下編寫“優雅”C++代碼時的兩句“真言”:

“真言”1:無論何時需要格式化一個數值,都應先轉換為一個字符串。這樣可保證每位數剛好占據一個字符。

“真言”2:在需要轉換為字符串時,請使用<sstream>庫。

轉換函數的接口非常簡潔:第一個參數是需被格式化的數值;第二個參數代表小數點後顯示的小數位,且應該具有一個默認值;返回值為一個string類型:

  1. ”,但能達到目的就行。以下是do_fraction()的完整代碼:  
  2.  string do_fraction(long double value, int decplaces=3)
  3. { ostringstream out; int prec= numeric_limits<long double>::digits10; // 18 
  4. out.precision(prec);//覆蓋默認精度 out<<value; string strout.str(); //從流中取出字符串 
  5. size_t n=str.find(DECIMAL_POINT); if ((n!=string::npos) //有小數點嗎? && (str.size()> n+decplaces)) /
  6. /後面至少還有decplaces位嗎? {str[n+decplaces]='\0';//覆蓋第一個多余的數 } str.swap(string(str.c_str()));
  7. //刪除nul之後的多余字符 return str;  

那它的原理是什麼呢?函數string::c_str()返回一個const char *代表此字符串對象,而這個值被用作一個臨時string對象的初始化值,接著,臨時對象又被用作str.swap()的參數,swap()會把值“123.45”賦給str。一些老一點的編譯器不支持默認模板參數,可能不會讓swap()通過編譯,如果是這樣的話,使用手工交換來代替:

  1. ”,但能達到目的就行。以下是do_fraction()的完整代碼:  
  2.  string do_fraction(long double value, int decplaces=3)
  3. { ostringstream out; int prec= numeric_limits<long double>::digits10; // 18 
  4. out.precision(prec);//覆蓋默認精度 out<<value; string strout.str(); //從流中取出字符串 
  5. size_t n=str.find(DECIMAL_POINT); if ((n!=string::npos) //有小數點嗎? && (str.size()> n+decplaces)) /
  6. /後面至少還有decplaces位嗎? {str[n+decplaces]='\0';//覆蓋第一個多余的數 } str.swap(string(str.c_str()));
  7. //刪除nul之後的多余字符 return str;  
  1. 如何正確編寫C++項目開發編寫項目計劃書
  2. C++庫函數進行學習探索總結筆記
  3. 深度演示C++語言的種種高安全性
  4. 詳細介紹如何准確無誤的編寫C++語言
  5. 深度演示C++語言的種種高安全性

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved