C++高级语言程序设计第二章.ppt_第1页
C++高级语言程序设计第二章.ppt_第2页
C++高级语言程序设计第二章.ppt_第3页
C++高级语言程序设计第二章.ppt_第4页
C++高级语言程序设计第二章.ppt_第5页
已阅读5页,还剩131页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

2020/5/23,1,C+高级语言程序设计,第2章基本数据类型与表达式北京邮电大学信息与通信工程学院,北京邮电大学信息与通信工程学院,2020/5/23,2,程序中最基本的要素是数据类型,根据数据类型可以为变量或常量分配内存空间,将变量、常量和运算符结合在一起组成表达式,进行复杂的运算和处理。,北京邮电大学信息与通信工程学院,2020/5/23,-3-,第2章基本数据类型与表达式,2.1词法记号和标识符2.2基本数据类型2.3变量和常量2.4运算符和表达式2.5基本输入输出2.6使用string类型处理字符串,北京邮电大学信息与通信工程学院,2020/5/23,-4-,2.1词法记号和标识符,北京邮电大学信息与通信工程学院,2.1词法记号和标识符,C+字符集英文字母:AZ,az数字字符:09特殊字符:+-*/%=!#.,()空格,2020/5/23,-5-,北京邮电大学信息与通信工程学院,2.1词法记号和标识符,C+关键字什么是关键字?预先定义好的标识符,C+编译器对其进行特殊处理。如何识别关键字?使用VC2005的编辑环境时,缺省是蓝色的字符即为关键字。,2020/5/23,-6-,北京邮电大学信息与通信工程学院,2.1词法记号和标识符,标识符标识符是程序员声明的单词,它命名程序正文中的一些实体,如函数名、变量名、类名、对象名等。C+标识符的构成规则如下:,2020/5/23,-7-,1、不能是C+的关键字;2、第一个字符必须是大写、小写字母或下划线;3、不包含空格和“+、-、;”等特殊字符;4、为方便输入,长度一般不超过31个字符。,北京邮电大学信息与通信工程学院,2.1词法记号和标识符,例如:合法的标识符:apple、_Student、_123、No1、max_num不合法的标识符:51job、maxnum、-abc,2020/5/23,-8-,注意:C+的标识符是大小写敏感的,即abcABC。,北京邮电大学信息与通信工程学院,2.1词法记号和标识符,分隔符分隔符用于分隔程序中的正文,在C+中使用下列字符作为分隔符:(),:;这些分隔符不表示实际的操作,仅用于构造程序。比如“;”用来作为一句完整语句的结束。,2020/5/23,-9-,北京邮电大学信息与通信工程学院,2.1词法记号和标识符,空白在C+语句中经常出现空白(制表符、空格、空行)等,通常都忽略不计。,2020/5/23,-10-,北京邮电大学信息与通信工程学院,2.2基本数据类型,北京邮电大学信息与通信工程学院,2020/5/23,-11-,2.2基本数据类型,什么是数据类型?数据是程序处理的对象,数据根据其本身的特点进行分类,从而形成不同的数据类型。例如:数学中有自然数、整数、实数不同类型的数据有不同的表示和处理方法,具有不同运算规则,2020/5/23,-12-,北京邮电大学信息与通信工程学院,2.2基本数据类型,基本数据类型整型:int字符型:char、wchar_t实型:float、double逻辑型:bool,2020/5/23,-13-,北京邮电大学信息与通信工程学院,2.2基本数据类型,修饰符在C+中描述为了更加准确的描述数据类型,提供了4个关键字用来修饰基本的数据类型:1、长型long2、短型short3、有符号signed4、无符号unsigned,2020/5/23,-14-,北京邮电大学信息与通信工程学院,1、short:仅用来修饰int,称为短整型,占2字节内存,也可直接简写为short;2、long:仅修饰int和double,在不同的编译环境中使用long修饰的double类型数据所占内存不同。3、unsigned:用来修饰char、short和int,表示该数据类型为无符号数。4、signed:用来修饰char、short和int,表示该数据类型为有符号数,为缺省设置。,2020/5/23,-15-,北京邮电大学信息与通信工程学院,2.2基本数据类型,数据类型与内存空间不同的数据类型,加上不同的修饰符就具有了不同的特点,在内存中占用的空间也不同,因而其所能表示的数值范围也不尽相同。内存单元的单位是字节,因此用来表示数据类型的长度的单位也是字节。,2020/5/23,-16-,北京邮电大学信息与通信工程学院,2.2基本数据类型,数据类型与内存空间特定数据类型在内存中占用的内存因机器的不同而不同整型int的长度等于机器的字长:16位机:int=2字节;32位机:int=4字节。,2020/5/23,-17-,北京邮电大学信息与通信工程学院,2.2基本数据类型,数据类型与内存空间如果需要编写可移植性好的程序,应将整型声明为short或long。因为short和long表示的数据长度是固定的,任何支持标准C+的编译器都是如此。,-18-,2020/5/23,北京邮电大学信息与通信工程学院,2.2基本数据类型,例2-1打印各种数据类型的长度编写一个程序,输出基本数据类型char,int,float,double,bool的长度。提示:使用sizeof(数据类型)能够获取不同数据类型的长度。,-19-,2020/5/23,北京邮电大学信息与通信工程学院,/例2-1显示各种数据类型的长度#includeusingnamespacestd;voidmain()coutchar:sizeof(char)字节n;coutint:sizeof(int)字节n;coutfloat:sizeof(float)字节n;coutdouble:sizeof(double)字节n;coutbool:sizeof(bool)字节n;,-20-,在32位机上运行结果char:1字节int:4字节float:4字节double:8字节bool:1字节,2020/5/23,北京邮电大学信息与通信工程学院,2.3变量和常量,-21-,北京邮电大学信息与通信工程学院,2020/5/23,2.3变量和常量,概述程序所处理的数据不仅分为不同的数据类型,而且每种类型的数据还分为变量和常量。程序在运行中就是通过这些变量和常量来操作数据的。,2020/5/23,-22-,北京邮电大学信息与通信工程学院,2.3变量,什么是变量?在C+中,变量是存储信息的地方。变量的实质是内存中的一个地址空间,在这个地址空间中可以进行数据的存储和读取。,2020/5/23,-23-,北京邮电大学信息与通信工程学院,定义变量的格式数据类型变量名1,变量名2,变量名n;例如:定义各种类型的变量intnum;floatf;charch;shorts;doublearea,length;,2020/5/23,-24-,2.3变量,北京邮电大学信息与通信工程学院,2.3变量,定义变量的实质例如:intnum;系统根据所指定的数据类型int,从地址xxxxxxxH开始,为变量num分配4个字节单元。变量num的取值范围为2312311。,2020/5/23,-25-,北京邮电大学信息与通信工程学院,2.3变量,定义变量的实质例如:intnum;编程时,可以直接使用变量名num对存储在该内存空间的数据,也就是变量值进行存取。变量名和地址xxxxxxxH之间的对应关系由系统来管理。,2020/5/23,-26-,北京邮电大学信息与通信工程学院,2.3变量,几点说明在创建或定义变量时,需要指明该变量的数据类型和名称。数据类型:决定变量的存储方式和可以进行的操作;变量名称:用来区分不同的变量。,2020/5/23,-27-,北京邮电大学信息与通信工程学院,2.3变量,几点说明在C+程序中使用变量,必须“先定义或声明,后使用”,而且只能定义一次。变量定义语句的位置,C+中没有要求,放在第一次使用该变量之前的任何位置均可以。,2020/5/23,-28-,建议:把变量定义语句放在首次使用它的地方,这样可以提高程序的可读性。,北京邮电大学信息与通信工程学院,2.3变量,变量的命名遵循标识符定义的规则,常用的命名约定有三种:1、Unix环境常用的命名法my_age、num_of_student2、驼峰式命名法myAge、numOfStudent3、匈牙利标记法iMyCar、bIsRight,2020/5/23,-29-,北京邮电大学信息与通信工程学院,2.3变量,变量的赋值使用赋值运算符“=”可以将一个值赋给变量。例如:unsignedshortage;age=18;也可以在定义变量的同时进行初始化:unsignedshortage=18;或unsignedshortage(18);,2020/5/23,-30-,北京邮电大学信息与通信工程学院,2.3变量,变量的赋值我们可以一次定义多个相同数据类型的变量,也可以一次为多个变量初始化:charch1=a,ch2=b;intheight=10,width=6,area;,2020/5/23,-31-,特性:变量可以被多次赋值,但每次赋值后,原值都会被新值覆盖。,北京邮电大学信息与通信工程学院,2.3变量,例2-2赋值运算符的使用#includeusingnamespacestd;voidmain()intmyAge=18;cout“myAge=”myAgeendl;myAge=20;cout“myAge=”myAgeendl;,-32-,2020/5/23,北京邮电大学信息与通信工程学院,运行结果:myAge=18myAge=20,2.3变量,typedef为已有的数据类型定义一个同义词,或者叫做别名。格式:typedef原类型名新类型名;例如:typedefunsignedshortintUINT16UINT16i;,2020/5/23,-33-,注意:typedef语句并没有定义一个新的数据类型,只是声明了原有数据类型的一个别名。,北京邮电大学信息与通信工程学院,2.3常量,常量常量代表一个固定的值。严格来说,常量又分成符号常量和常数。符号常量:是用标识符表示的常量;常数:程序中使用的具体的数据。,2020/5/23,-34-,北京邮电大学信息与通信工程学院,2.3常量,符号常量C+中提供了一个关键字const,用来区分常量和变量。由于常量在程序运行过程中不能够被改变,所以要求常量在定义的时候必须进行初始化。符号常量的定义格式:const数据类型常量名=常量值;例如:constfloatPI=3.14159;,2020/5/23,-35-,北京邮电大学信息与通信工程学院,2.3常量,define关键字在C语言中使用预编译指令#define也能够定义常量。例如:#definePI3.1415927,说明:该语句属于预编译指令,不属于C+语句,因而行尾不需要使用分号。并且由于C+是向下兼容的,因而C语言的程序能够在C+的编译器下顺利运行。但是在C+编程中,建议使用const替代#define定义常量。,2020/5/23,-36-,北京邮电大学信息与通信工程学院,2.3常量,编程时使用符号常量可以增强程序的可读性可以增强程序的可维护性,2020/5/23,-37-,北京邮电大学信息与通信工程学院,2.3常量,整型常数C+中的整型常数可以使用多种数制十进制数:1008进制数:014416进制数:0 x64整型常数默认是int类型用U或u表示无符号整型,如65535U。用L或l表示长整型,如123L。,2020/5/23,-38-,北京邮电大学信息与通信工程学院,2.3常量,实型常数1、小数形式例如:0.123、23.122、指数形式表示形式:aEb代表数值:a10b例如:123e5或123E5=123105,2020/5/23,-39-,注意:b必须是十进制整数,a可以是十进制整数或者小数形式的实数,并且数字a和b都不可以省略,北京邮电大学信息与通信工程学院,2.3常量,实型常数实型常数默认为double型可用后缀F(f)表示实数常数为float型。可用后缀L(l)表示实数常数为longdouble型。,2020/5/23,-40-,北京邮电大学信息与通信工程学院,2.3常量,字符常数1、用单引号扩起来的一个字符,例如:a、?。2、转义字符以开头的字符序列,代表特殊的意义。例如:n、t、”,2020/5/23,-41-,北京邮电大学信息与通信工程学院,a0 x07bell(响铃)n0 x0A换行r0 x0D回车t0 x09制表符v0 x0B垂直跳格b0 x08Backspace0 x5C0 x22双引号0 x27单引号ooo1-3位8进数xhh1-2位16进数,2020/5/23,-42-,北京邮电大学信息与通信工程学院,例2-3:打印特殊字符,#includeusingnamespacestd;voidmain()cout“输出字母:”aaendl;cout“输出字母:”nn;,运行结果:输出字母:a(蜂鸣器响一声)输出字母:n(换行),2020/5/23,-43-,北京邮电大学信息与通信工程学院,2.3常量,字符常数反斜线还可以和13位八进制数或以x开始的12位十六进制数结合表示任何ASCII字符。例如:例2-3中的输出还可以写为cout“输出字母:”x61x07endl;cout“输出字母:”x6Ex0A;,2020/5/23,-44-,北京邮电大学信息与通信工程学院,2.3常量,字符数据的存储在内存中,字符数据以ASCII码存储,可看成是单字节整数表示,所以,C+中字符数据和整数可以相互赋值。例2-4字符数据和整型数据的转换,2020/5/23,-45-,北京邮电大学信息与通信工程学院,/例2-4:同样数据的不同输出#includeusingnamespacestd;voidmain()intn=a;charch=97;cout”按整数输出内容:”nendl;cout”按字符输出内容:”chendl;,运行结果:按整数输出内容:97按字符输出内容:a,注意:变量在输出时,根据其本身的数据类型进行输出。,2020/5/23,-46-,北京邮电大学信息与通信工程学院,2.3常量,字符串常量由一对双引号括起来的字符序列。例如:“howdoyoudo?”“helloworld!”,2020/5/23,-47-,北京邮电大学信息与通信工程学院,2.3常量,字符串常量在内存中的存储字符串常量在内存中除了存储所包含字符外,还需要存储一个结束符0。一个字符数据在内存中占用1字节的空间。,2020/5/23,-48-,注意:字符串“A”与字符A的不同,北京邮电大学信息与通信工程学院,2.3常量,思考:字符串“x07Operatingtsystem”有几个字符?显示结果如何?,2020/5/23,-49-,北京邮电大学信息与通信工程学院,2.3常量,逻辑常数逻辑型常数只有两个:false(假)和true(真)。在显示器上显示为0和1。,2020/5/23,-50-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,2.4运算符和表达式,1、表达式2、语句和块3、运算符赋值运算符、算术运算符、关系运算符、逻辑运算符、位运算符、条件运算符、逗号运算符,2020/5/23,-52-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,表达式变量、常量是存放数据的地方,那么在C+语言中这些数据是如何处理和计算的呢?在C+语言中将变量、常量和运算符有机结合在一起组成的就是表达式,利用表达式C+可以进行复杂的运算和处理。,2020/5/23,-53-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,表达式表达式是操作符、操作数和分隔符号组成的序列。操作符:+-*/等操作数:变量、常量、数组等表达式总能返回一个值作为表达式的结果。,2020/5/23,-54-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,表达式例如:3.2/简单表达式,值为3.22+3/常量表达式,值为5a/简单表达式,值为变量a的值x=(a+b)*c/较为复杂的表达式y=x=a+b/表达式是可以嵌套的,2020/5/23,-55-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,语句和块由表达式和结尾的“;”组成一个C+语句。多条C+语句通过大括号括起来,组成一个块语句。一般来说属于同一个逻辑关系的多条语句组成块语句。,2020/5/23,-56-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,语句和块例如:实现将变量x和y交换的语句块inttemp=x;x=y;y=temp;,2020/5/23,-57-,注意:结束语句块的大括号外不用分号。,北京邮电大学信息与通信工程学院,2.4运算符和表达式,运算符运算符具有优先级和结合性。优先级:级别高的先运算,级别低的后运算。例如:*/高于+-结合性:自左向右结合还是自右向左结合。例如:1+2+3,+自左向右结合。,2020/5/23,-58-,北京邮电大学信息与通信工程学院,2020/5/23,-59-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,运算符根据运算符对操作数的要求不同,分成:一元运算符:仅需要一个操作数的运算符,例如+等二元运算符:需要两个操作数的运算符,例如:+、-、*、/等,三元运算符:需要三个操作数的运算符,只有条件运算符“?:”。,2020/5/23,-60-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,赋值运算符赋值运算符就是:“=”例如:floatf=3.15左值:可以合法的放在“=”左边的操作数。右值:可以合法的放在“=”右边的操作数。,2020/5/23,-61-,注意:并不是所有的操作数都可以作为左值。符号常量就不能作左值;带运算符的表达式一般也不能作为左值。,北京邮电大学信息与通信工程学院,2.4运算符和表达式,赋值运算符例如:floatx,y;constfloatPI=3.14;x=3.5;/正确3.5=x;/有语法错误y=x;/正确y+2=x-10;/语法错误PI=x;/语法错误,2020/5/23,-62-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,算术运算符C+提供的算术运算符包括“+,-,*,/,%,+,-”二元运算符:+(加),-(减),*,/,%一元运算符:+(正号),-(负号),+,-,2020/5/23,-63-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,算术运算符几点说明:“/”根据操作数不同,运算规律也不同:整型数为整除运算:例如5/2=2;浮点数为通常意义的除法:即5.0/2.0=2.5。“%”取余数运算符,只能对整型数进行操作,余数的正负由被除数决定,不允许对浮点数进行操作。例2-5“/”和“%”运算符的使用,2020/5/23,-64-,北京邮电大学信息与通信工程学院,/例2-5“/”和“%”运算符的使用。#includeusingnamespacestd;voidmain()inta=-4,b=3;couta=ab=bendl;couta/b=a/bendl;cout(float)a/b=(float)a/bendl;couta%b=a%bendl;coutb%a=b%aendl;,运行结果:a=-4b=3a/b=-1(float)a/b=-1.33333a%b=-1b%a=3,2020/5/23,-65-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,算术运算符C+中提供了两个特殊的运算符:+(自增),表示将操作数加1;-(自减)表示将操作数减1前置(+i):先自身加1,然后再将加1的值作为(+i)表达式的值;后置(i+):将i作为(i+)表达式的值,然后自身再加1。例2-6自增运算符的使用,2020/5/23,-66-,北京邮电大学信息与通信工程学院,/例2-6自增运算符的使用#includeusingnamespacestd;voidmain()inti=1;cout”i=”iendl;cout”i+:”i+endl;cout”i=”iendl;cout”+i:”+iendl;cout”i=”iendl;,1,1,2,3,3,北京邮电大学信息与通信工程学院,运行结果:i=1i+:1i=2;+i:3i=3,2020/5/23,-67-,2.4运算符和表达式,算术运算符在C+中可以将算术运算符和赋值运算符结合在一起进行运算,因此C+还提供5种复合的赋值运算符:+=,-=,*=,/=和%=。例如:x+=y相当于x=x+yx-=y相当于x=x-yx*=y相当于x=x*yx/=y相当于x=x/yx%=y相当于x=x%y,2020/5/23,-68-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,算术运算符例如:#includeusingnamespacestdvoidmain()intx=2,y=3;x*=y+8;coutxendl;,原因:x*=y+8等价于x=x*(y+8),/显示22,2020/5/23,-69-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,2020/5/23,-70-,算术运算符算术运算符的优先级:1、+(正号),-(负号),+,-2、*,/,%3、+、-4、=、+=、-=、*=、/=、%=,由高到低,北京邮电大学信息与通信工程学院,2.4运算符和表达式,算术运算符溢出是指运算结果超出了表达式的数据类型能够表示的范围。在进行算术运算时,很可能出现溢出。溢出不会引起编译错误的,但运行结果会出现偏差。例如:shortinti=20000,j=30000,k;cout(k=i+j)、=、a+5;coutd2;cout”a=”(int)aendl;,2020/5/23,-90-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,移位运算举例chara=2;a=a1;cout”a=”(int)a=。例如:xcouty?x:y)endl;,2020/5/23,-94-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,逗号运算符逗号表达式的语法格式为:表达式1,表达式2,表达式n;C+顺序计算表达式1,表达式2,表达式n的值,并将最后一次计算的结果作为逗号表达式的结果。例如:inta,b,c,d;d=(a=1,b=2,c=a+b,a+b+c);coutdendl;,2020/5/23,-95-,北京邮电大学信息与通信工程学院,运行结果:6,2.4运算符和表达式,数据类型转换当表达式中出现多种数据类型的混合运算时,往往需要进行类型转换。表达式中的类型转换分成两种:1、隐式类型转换2、强制类型转换。,2020/5/23,-96-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,隐式类型转换各种二元运算符在进行运算时都要求两个操作数的数据类型一致。如果类型不一致,则系统自动对数据进行转换(隐式类型转换)。转换的基本原则:将精度较低、范围较小的类型转换成精度较高、范围较大的类型。charshortintlongfloatdouble,2020/5/23,-97-,北京邮电大学信息与通信工程学院,隐式类型转换例2-8数据类型的自动转换。#includeusingnamespacestd;voidmain()charch=a;inti=100;doubled=123.09;coutch+iendl;/自动转换为int型coutch+i+dendl;/自动转换为double型,运行结果:197320.09,2.4运算符和表达式,提示:在转换过程中不会造成数据精度的丢失。,2020/5/23,-98-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,隐式类型转换对于同一种精度的无符号数和有符号数,在进行算术运算中,有符号数向着无符号数方向进行隐式类型转换:signedunsigned。例如:inta=100;unsignedinti=99;couti-aendl;,2020/5/23,-99-,思考:如果将unsignedinti=99;改为unsignedshorti=99;结果如何?,北京邮电大学信息与通信工程学院,2.4运算符和表达式,隐式类型转换逻辑运算符要求参与运算的操作数为bool类型,如果是其他类型,则系统自动将其转换成bool类型。转换规则:0为false,非0为true。赋值运算符要求“=”左右两边的操作数数据类型相同,如果类型不一致,则自动将右边的操作数类型向着左边的操作数类型转换。例如:inti=3.15;coutiendl;,2020/5/23,-100-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,C风格的强制类型转换语法格式为:(数据类型名)表达式或:数据类型名(表达式)例如:inti=97;cout(char)iendl;floatf=3.75;cout(int)fendl;,2020/5/23,-101-,北京邮电大学信息与通信工程学院,2.4运算符和表达式,C+的强制类型转换符语法格式为:static_cast(表达式)例如:inti=97;cout(i)(f)”就可以将键盘键入的数据读入到变量中。语法格式为:cin变量1变量2变量n;例如:inta,b;charch;cinabch;,2020/5/23,-106-,北京邮电大学信息与通信工程学院,2.5基本输入输出,例2-9:计算从键盘输入的若干个整数的和。#includeusingnamespacestd;voidmain()intsum=0,value;while(cinvalue)/如果能从cin提取数值,sum+=value;/则cin的值为真,执行循环coutsumis:sumendl;,运行结果:12345z/键盘输入sumis:15,2020/5/23,-107-,北京邮电大学信息与通信工程学院,2.5基本输入输出,标准输出流coutcout负责将变量或常量中的数据输出到屏幕,使用插入操作符“”就可以将变量或常量的数据显示在屏幕上。cout能够自动识别“”后面的数据类型并进行显示,并且可以从左到右一次显示多个变量。例如:coutbch;cout”a=”a”b=”b”ch=”chendl;,运行结果:请按顺序输入两个整数和一个字符:12a/键盘输入a=1b=2ch=a/屏幕输出,2020/5/23,-109-,北京邮电大学信息与通信工程学院,2.5基本输入输出,IO流的格式控制库文件:iomanip常用操纵符:setfill(c)设置填充字符setw(n)设置域宽为nsetiosflags(ios:left)设置数据输出左对齐setiosflags(ios:right)设置数据输出右对齐,2020/5/23,-110-,注意:用cout输出数据默认的对齐方式是右对齐。,北京邮电大学信息与通信工程学院,2.5基本输入输出,IO流的格式控制setw(n)设置域宽,即设置“”符号后面的数据占用的屏幕宽度。例如:coutsetw(8)asetw(8)bendl;,2020/5/23,-111-,北京邮电大学信息与通信工程学院,输出结果:_a_b,2.5基本输入输出,IO流的格式控制setfill(c)设置填充字符,即“”符号后面的数据长度小于域宽时,使用什么字符进行填充。例如:coutsetfill(*)setw(5)aendl;,2020/5/23,-112-,北京邮电大学信息与通信工程学院,输出结果:*a,例2-11setw()和setfill()的综合使用。#include#includeusingnamespacestd;voidmain()coutsetfill(*)setw(2)nsetw(3)nsetw(4)nsetw(5)nsetw(6)nsetw(7)nsetw(8)n;,运行结果:*,2.5基本输入输出,2020/5/23,-113-,北京邮电大学信息与通信工程学院,2.5基本输入输出,IO流的格式控制关于setw()几点说明:除了setw()控制符外,其他控制符一旦设置,则对其后的所有输入输出产生影响。而setw()控制符只对其后输出的第一个数据有效,对其他数据没有影响。例如:coutsetw(8)abendl;,2020/5/23,-114-,输出结果:_ab,北京邮电大学信息与通信工程学院,2.5基本输入输出,IO流的格式控制关于setw()几点说明:setw()的默认为setw(0),意思是按实际输出。如果输出的数值占用的宽度超过setw(intn)设置的宽度,则按实际宽度输出。例如:floatf=0.12345;coutsetw(3)fendl;,2020/5/23,-115-,输出结果:0.12345,北京邮电大学信息与通信工程学院,2.5基本输入输出,I/O流的格式控制C+默认输出浮点数的有效位为6位,那么要想控制输出的数据的长度,该如何呢?例如:floatf=3.1234567;如何让显示结果为3.12?C+提供了setprecision(intn)可以控制显示浮点数的有效位。例2-12控制浮点数的数字个数。,2020/5/23,-116-,北京邮电大学信息与通信工程学院,/例2-12控制浮点数的数字个数。#include#includeusingnamespacestd;voidmain()floatf=17/7.0;coutfendl;coutsetprecision(0)fendl;coutsetprecision(1)fendl;coutsetprecision(2)fendl;coutsetprecision(3)fendl;coutsetprecision(6)fendl;coutsetprecision(8)fendl;,运行结果:2.428572.4284722.42.432.428572.4285715,2020/5/23,-117-,北京邮电大学信息与通信工程学院,2.5基本输入输出,I/O流的格式控制如何控制小数的位数?setiosflags(ios:fixed)控制符是用定点方式表示浮点数,将setprecision(intn)和setiosflags(ios:fixed)结合,可以使用setprecision(intn)控制小数点右边小数的个数。当设置为定点格式时,若不设置精度则显示6位有效小数。例2-13定点小数的输出。,2020/5/23

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论