讲述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++语言的种种高安全性
责任编辑:chenqingxiang 来源: NET130
相关推荐

2021-10-19 14:04:28

C++类型数字

2020-09-15 12:57:46

C 语言浮点数内存

2023-07-05 08:00:58

Redis数据库

2017-10-16 10:42:27

前端JavaScript浮点数

2018-08-24 10:16:23

内存浮点数存储

2020-10-12 06:38:08

存储定点数

2011-05-25 14:10:38

浮点数

2021-11-29 14:47:54

C++编程语言

2009-08-03 14:25:59

C#日期格式化

2015-12-02 10:21:34

JavaScript浮点数精度调整

2010-02-01 16:46:07

C++格式化字符串

2024-02-22 09:46:04

C++字符串格式化开发

2009-08-03 16:24:05

C#格式化

2010-07-22 17:39:44

2010-01-21 13:33:44

C++基类

2009-05-19 10:10:01

Oracle时间加减时间操作

2009-07-30 16:23:07

C#日期格式化

2009-09-04 12:22:41

C#日期格式化

2009-07-30 16:40:03

C#日期格式化

2010-02-06 09:53:26

C++ void
点赞
收藏

51CTO技术栈公众号