C++编程中的格式化输出详解

在输出数据时,为简便起见,往往不指定输出的格式,由系统根据数据的类型采取默认的格式,但有时希望数据按指定的格式输出,如要求以十六进制或八进制形式输出一个 整数,对输出的小数只保留两位小数等。有两种方法可以达到此目的。一种是使用控制符的方法;第2种是使用流对象的有关成员函数。分别叙述如下。
使用控制符控制输出格式

控制格式的使用方法这里不再赘述,仅举例说明
[例] 用控制符控制输出格式。

#include <iostream>
#include <iomanip>//不要忘记包含此头文件
using namespace std;
int main()
{
  int a;
  cout<<"input a:";
  cin>>a;
  cout<<"dec:"<<dec<<a<<endl; //以十进制形式输出整数
  cout<<"hex:"<<hex<<a<<endl; //以十六进制形式输出整数a
  cout<<"oct:"<<setbase(8)<<a<<endl; //以八进制形式输出整数a
  char *pt="China"; //pt指向字符串"China"
  cout<<setw(10)<<pt<<endl; //指定域宽为,输出字符串
  cout<<setfill('*')<<setw(10)<<pt<<endl; //指定域宽,输出字符串,空白处以'*'填充
  double pi=22.0/7.0; //计算pi值
  //按指数形式输出,8位小数
  cout<<setiosflags(ios::scientific)<<setprecision(8);
  cout<<"pi="<<pi<<endl; //输出pi值
  cout<<"pi="<<setprecision(4)<<pi<<endl; //改为位小数
  cout<<"pi="<<setiosflags(ios::fixed)<<pi<<endl; //改为小数形式输出
  return 0;
}

运行结果如下:

input a:34(输入a的值)
dec:34          (十进制形式)
hex:22          (十六进制形式)
oct:42          (八进制形式)
     China        (域宽为)
*****China        (域宽为,空白处以'*'填充)
pi=3.14285714e+00    (指数形式输出,8位小数)
pi=3.1429e+00      (指数形式输出,4位小数)
pi=3.143         (小数形式输出,精度仍为)

用流对象的成员函数控制输出格式

除了可以用控制符来控制输出格式外,还可以通过调用流对象cout中用于控制输出格式的成员函数来控制输出格式。用于控制输出格式的常用的成员函数见表

流成员函数setf和控制符setiosflags括号中的参数表示格式状态,它是通过格式标志来指定的。格式标志在类ios中被定义为枚举值。因此在引用这些格式标志时要在前面加上类名ios和域运算符“::”。格式标志见下表

[例] 用流控制成员函数输出数据。

#include <iostream>
using namespace std;
int main( )
{
  int a=21
  cout.setf(ios::showbase);//显示基数符号(0x或)
  cout<<"dec:"<<a<<endl;     //默认以十进制形式输出a
  cout.unsetf(ios::dec);     //终止十进制的格式设置
  cout.setf(ios::hex);      //设置以十六进制输出的状态
  cout<<"hex:"<<a<<endl;     //以十六进制形式输出a
  cout.unsetf(ios::hex);     //终止十六进制的格式设置
  cout.setf(ios::oct);      //设置以八进制输出的状态
  cout<<"oct:"<<a<<endl;     //以八进制形式输出a
  cout.unseft(ios::oct);
  char *pt="China";       //pt指向字符串"China"
  cout.width(10);        //指定域宽为
  cout<<pt<<endl;        //输出字符串
  cout.width(10);        //指定域宽为
  cout.fill('*');        //指定空白处以'*'填充
  cout<<pt<<endl;        //输出字符串
  double pi=22.0/7.0;      //输出pi值
  cout.setf(ios::scientific);  //指定用科学记数法输出
  cout<<"pi=";          //输出"pi="
  cout.width(14);        //指定域宽为
  cout<<pi<<endl;        //输出pi值
  cout.unsetf(ios::scientific); //终止科学记数法状态
  cout.setf(ios::fixed);    //指定用定点形式输出
  cout.width(12);        //指定域宽为
  cout.setf(ios::showpos);   //正数输出“+”号
  cout.setf(ios::internal);   //数符出现在左侧
  cout.precision(6);      //保留位小数
  cout<<pi<<endl;        //输出pi,注意数符“+”的位置
  return 0;
}

运行情况如下:

dec:21(十进制形式)
hex:0x15         (十六进制形式,以x开头)
oct:025         (八进制形式,以开头)
     China        (域宽为)
*****China        (域宽为,空白处以'*'填充)
pi=**3.142857e+00    (指数形式输出,域宽,默认位小数)
+***3.142857       (小数形式输出,精度为,最左侧输出数符“+”)

对程序的几点说明:
1) 成员函数width(n)和控制符setw(n)只对其后的第一个输出项有效。如:

  cout. width(6);
  cout <<20 <<3.14<<endl;

输出结果为 203.14

在输出第一个输出项20时,域宽为6,因此在20前面有4个空格,在输出3.14时,width (6)已不起作用,此时按系统默认的域宽输出(按数据实际长度输出)。如果要求在输出数据时都按指定的同一域宽n输出,不能只调用一次width(n),而必须在输出每一项前都调用一次width(n>,上面的程序中就是这样做的。

2) 在表中的输出格式状态分为5组,每一组中同时只能选用一种(例如dec、hex和oct中只能选一,它们是互相排斥的)。在用成员函数setf和控制符setiosflags设置输出格式状态后,如果想改设置为同组的另一状态,应当调用成员函数unsetf(对应于成员函数self)或resetiosflags(对应于控制符setiosflags),先终止原来设置的状态。然后再设置其他状态,大家可以从本程序中看到这点。程序在开始虽然没有用成员函数self和控制符setiosflags设置用dec输出格式状态,但系统默认指定为dec,因此要改变为hex或oct,也应当先用unsetf 函数终止原来设置。如果删去程序中的第7行和第10行,虽然在第8行和第11行中用成员函数setf设置了hex和oct格式,由于未终止dec格式,因此hex和oct的设置均不起作用,系统依然以十进制形式输出。

同理,程序倒数第8行的unsetf 函数的调用也是不可缺少的。

3) 用setf 函数设置格式状态时,可以包含两个或多个格式标志,由于这些格式标志在ios类中被定义为枚举值,每一个格式标志以一个二进位代表,因此可以用位或运算符“|”组合多个格式标志。如倒数第5、第6行可以用下面一行代替:
    cout.setf(ios::internal I ios::showpos);  //包含两个状态标志,用"|"组合

4) 可以看到:对输出格式的控制,既可以用控制符,也可以用cout流的有关成员函数,二者的作用是相同的。控制符是在头文件iomanip中定义的,因此用控制符时,必须包含iomanip头文件。cout流的成员函数是在头文件iostream 中定义的,因此只需包含头文件iostream,不必包含iomanip。许多程序人员感到使用控制符方便简单,可以在一个cout输出语句中连续使用多种控制符。

(0)

相关推荐

  • 解析C++ 浮点数的格式化输出

    C++格式化输出浮点数 复制代码 代码如下: #include <iostream>using std::cout;using std::endl;using std::fixed;using std::scientific;int main(){   double x = 0.001234567;   double y = 1.946e9;   cout << "Displayed in default format:" << endl <&

  • C++编程中的格式化输出详解

    在输出数据时,为简便起见,往往不指定输出的格式,由系统根据数据的类型采取默认的格式,但有时希望数据按指定的格式输出,如要求以十六进制或八进制形式输出一个 整数,对输出的小数只保留两位小数等.有两种方法可以达到此目的.一种是使用控制符的方法:第2种是使用流对象的有关成员函数.分别叙述如下. 使用控制符控制输出格式 控制格式的使用方法这里不再赘述,仅举例说明 [例] 用控制符控制输出格式. #include <iostream> #include <iomanip>//不要忘记包含此头

  • Android编程中HTTP服务用法详解

    本文实例讲述了Android编程中HTTP服务用法.分享给大家供大家参考,具体如下: 在Android中,除了使用java.net包下的API访问HTTP服务之外,我们还可以换一种途径去完成工作.Android SDK附带了Apache的HttpClient API.Apache HttpClient是一个完善的HTTP客户端,它提供了对HTTP协议的全面支持,可以使用HTTP GET和POST进行访问.下面我们就结合实例,介绍一下HttpClient的使用方法. 我们新建一个http项目,项目

  • C#函数式编程中的缓存技术详解

    缓存技术 该节我们将分成两部分来讲解,第一部分为预计算,第二部分则为缓存.缓存这个技术对应从事开发的人员来说是非常熟悉的,从页面缓存到数据库缓存无处不在,而其最重要的特点就是在第一次查询后将数据缓存,在以后的查询过程中就无需重新计算而直接从内存中将结果返回,大大提高了性能,而我们这里的缓存则集中运用在函数上.  预计算 可能一些人并不能立马理解这个词的含义,所以我们就简单的从生活例子出发介绍一下.很多人在工作中一定会这样做事,比如上级吩咐了你一件事,但是这件事的后半部分要等另一个同事做好之后把对

  • C#函数式编程中的部分应用详解

    何谓函数式编程 相信大家在实际的开发中,很多情况下完成一个功能都需要借助多个类,那么我们这里的基本单元就是类.而函数式编程则更加细化,致使我们解决一个功能的基本单元是函数,而不是类,每个功能都是由多个函数构成,并且函数之间没有直接的关系.如果简单的文字描述还不足以让你理解,下面我们就配以图来演示. 如下图所示,图左是我们设计好的三个函数,而右边则是我们需要实现的功能.而我们需要做的就是利用这三个函数去完成对应的三个功能,笔者在这里只是进行简单而又形象的表述,实际的开发过程可能需要更多的函数,并且

  • Linux中top命令输出详解

    前言 Linux下的top命令我相信大家都用过,自从我接触Linux以来就一直用top查看进程的CPU和MEM排行榜.但是top命令的其他输出结果我都没有了解,这些指标都代表什么呢,什么情况下需要关注呢?以及top命令输出结果的来源数据是什么呢,又是怎么一个计算原理呢? 演示环境 # uname -a Linux VM_1_11_centos 3.10.0-693.el7.x86_64 #1 SMP Tue Aug 22 21:09:27 UTC 2017 x86_64 x86_64 x86_6

  • C/C++编程中const的使用详解

    目录 1 概述:const和define的区别 2. 修饰局部变量 3. 常量指针与指针常量 4. 修饰函数的参数 5. 修饰函数的返回值 6. 修饰全局变量 总结 1 概述:const和define的区别 先看一个典型的程序: #include<iostream> using namespace std; int main() { int num = 1; #define t1 num + num #define t2 t1 % t1 cout << "t2 is &q

  • Java 添加、删除、格式化Word中的图片步骤详解( 基于Spire.Cloud.SDK for Java )

    本文介绍使用Spire.Cloud.SDK for Java提供的ImagesApi接口来操作Word中的图片.具体可通过addImage()方法添加图片.deleteImage()方法删除图片.updateImageFormat()格式化Word中的图片以及getImageFormat()获取Word中的图片格式等.操作方法和代码示例可参考下文中的步骤. 步骤1:导入jar文件 创建Maven项目程序,通过maven仓库下载导入.以IDEA为例,新建Maven项目,在pom.xml文件中配置m

  • JavaScript中使用toLocaleString数字格式化处理详解

    目录 toLocaleString 偷懒小帮手啊~ Number.prototype.toLocaleString() 1. 数字分割成千分位 2. 保留几位小数 3. 使用的整数数字的最小数目minimumIntegerDigits 4. 使用的有效数字的最小数目minimumSignificantDigits 5. 使用的有效数字的最大数目maximumSignificantDigits 6. 展示的样式style toLocaleString 偷懒小帮手啊~ 项目中给数字做格式化处理的问题

  • python中 logging的使用详解

    日志是用来记录程序在运行过程中发生的状况,在程序开发过程中添加日志模块能够帮助我们了解程序运行过程中发生了哪些事件,这些事件也有轻重之分. 根据事件的轻重可分为以下几个级别: DEBUG: 详细信息,通常仅在诊断问题时才受到关注.整数level=10 INFO: 确认程序按预期工作.整数level=20 WARNING:出现了异常,但是不影响正常工作.整数level=30 ERROR:由于某些原因,程序 不能执行某些功能.整数level=40 CRITICAL:严重的错误,导致程序不能运行.整数

  • 基于C++中setiosflags()的用法详解

    cout<<setiosflags(ios::fixed)<<setiosflags(ios::right)<<setprecision(2); setiosflags 是包含在命名空间iomanip 中的C++ 操作符,该操作符的作用是执行由有参数指定区域内的动作:   iso::fixed 是操作符setiosflags 的参数之一,该参数指定的动作是以带小数点的形式表示浮点数,并且在允许的精度范围内尽可能的把数字移向小数点右侧:   iso::right 也是se

随机推荐