C++总结

C++总结

第二单元 顺序结构程序设计
第一课 cout语句
1.cout语句(输出):
cout<<项目1<<项目2<<……<<项目n;
①项目是表达式,测输出表达式的值;
②项目是endl表示换行;
③项目加“ ”,则输出“ ”内内容;
④<<→是插入运算符。
第二课 数据类型
1.
①整型
int 4(32位) -2147483648~2147483647
short 2(16位) -32768~32767
long 4(32位)-2147483648~2147483647
long long 8(64位)-2^63 ~2^63-1
②布尔型
bool 1(8位)0或1(严格意义上是非0)
③字符型
char 1(8位)-128~127
④实型(浮点型)
float 4(32位)-3.4E+38~3.4E+38,6~7位有效数字
double 8(64位)-1.79E+308~1.79E+308,15~16位有效数字long double 不确定(与编译器有关)-1.2E+4932~1.2E+4932,18~19位有效数字
附:(整数还有“无符号”型,其取值只会是正数和0,范围扩大一倍)
(在C++中,字符型数据可以直接参与整型或实型数据的运算,按照其ASCII码值使用。)
(int(ch)表示把ch字符强制转换成int类型)
(sizeof函数的作用是获取各种数据类型的长度。例如size of(long)等于4。另外,使用sizeof函数可以得到一个特定变量的储存空间大小。例如:对于int型变量x,size of(x)的值也等于4。)
第三课 变量与常量
1.常量 类型名 const 常量名; const类型名 常量名;
2.变量 类型名 变量名1,变量名2,…变量名n;
附: ①常量名通常用大写字母表示
②命名规则:
1)标识符不能和系统里的关键字同名;
2)标识符只能包括字母、数字、和下划线“_”,并且开头只能是字母或下划线;
3)标识符必须先定义后使用;
4)标识符不能重复使用;
5)标识符区分大小写;
第四课字符与字符串
1.字符变量:存放单个字符的变量,(用一对单引号括起来 如‘a’)
2.字符串变量:存放一串有若干字符的变量,(用一对双引号括起来,如“a”→里面有两个字符,若双引号里什么都没有,称为空字符串→与双引号内有一个空格的字符串不一样。)
格式: char 标识符1,标识符2,…,标识符n;
附: 字符变量在内存中占用一个字节(存的是ASCII值)
3.转义字符
①\n——换行——10
②\——反斜杠字符\——92
③\`——单撇号字符`——39
④ “——双撇号字符”——34
⑤\0——空操作字符——0
(字符形式——含义——ASCII码值)
附: ① 在C++中,单个字符的输入输出也可以通过字符输入输出函数进行
getchar(输入字符),表示从终端输入一个字符
putchar(输出字符),表示向终端输出一个字符
②输入输出字符串用gets,puts,也可以用字符数组char s[ ]存放字符串,也可以用STL中的string类型(C语言中没有,只在C++中存在如:string s ="1234 asdf")
③C语言开头文件<cstdio>
④每一个字符的结尾都要加一个“字符串结束标志”,而且是系统自动添加上去的,C++规定以转义字符“\0”,作为字符串结束标志,所以字符串“hello”在计算机中占用6字节。
第五课 算术运算符
①C++中的常用算术运算符有+、-、、/、%(模-取余)和括号
② 运算优先级为:先算括号里的再算乘法,除法、模最后算加法减法同一级别的按照类型从左往右依次计算表达式的计算结果称为表达式的值。
③任何一个表达式都有值。
④整数除整数商一定是整数。
常用数学函数
①int abs(int i)返回整型参数i的绝对值 abs(-5)=5
② double fabs (double x) 返回双精度参数x的绝对值 fabs(-2.5)=2.5
③double ceil(double x)返回不小于x的最小整数(上取整)ceil(2.5)=3.0 ceil(-2.5)=-2.0
④double floor(double x)返回不大于的x最大整数(下取整)floor(2.5)=2.0
⑤double pow(double x,double y)返回x的y次幂的值 pow(2,3)=8
⑥double sqrt(double x)返回x的平方根 sqrt(9)=3
⑦double log(double x)返回ln(x)的值(以e为底) log(2.71)≈1 log(8)/log(2)=3
⑧ double log10(double x)返回lg(x)(以10为底)log10(100)=2
附: 在使用这些数学函数前,必须添加“cmath”或“math.h”头文件
第六课 cin语句
cin是C++中实现输入功能的语句,格式:
cin>>项目1>>项目2>>…>>项目n;
注意三个一致:数据个数一致、输入顺序一致、数据类型一致。
一定要注意键盘输入数据的类型与定义的变量类型保持一致。
附: setprecision(n),精度,表示保留n位小数
第七课 赋值语句
格式:变量名=值或表达式; “=”为赋值号
注意:a=b(把b的值赋值给a),a==b(a等于b),意义完全不同。
(1)算数复合
例如,“a=a+x;”可以写成“a+=x;”类似其他类型的还有“a-=x;”“a
=x;”“a/=x;”“a%=x;”等
(2)赋值复合
C++支持在一个表达式里出现连续的赋值符号,即一次给几个变量赋同一个值。此时计算顺序是从右到左,有括号存在的,先计算括号内的表达式。
(3)逗号表达式
在C++中,允用逗号连接几个表达式,构成一个更大的表达式,称为“逗号表达式”。
格式:表达式1, 表达式2,…,表达式n;
各个表达式的计算顺序是从左往右,最终整个表达式的值是“表达式n”的值。
附: 逗号运算符的优先级低于赋值号的优先级
第八课 复合运算符
自加运算符“++”:i++或++i
自减运算符“--”:i--或--i
在单独使用时,其作用相同,都相当于i=i+1、i=i-1
但是,在赋值语句中使用时,两种用法结果就不一样了:
++i和--i是在使用i前,先把i的值加1或减1;
而i++和i--是在使用i后,再把i的值加1和减1。
注意:①++和--只能用于变量(5++或者(a+b)++不行)
②在遇到多个运算符时,计算的结合方向按照自右向左进行
第九课 运算规则
部分运算符的优先级和结合性(序号为优先级)
①( )、[ ] 从左往右
② ! 、+(正)、-(负)、~、++、-- 从右往左
③ *、/、% 从左往右
④ +(加)、-(减) 从左往右
⑤<<、>>、>>> 从左往右
⑥<、<=、>、>=、instanceof 从左往右
⑦==、!= 从左往右
⑧&(按位与) 从左往右
⑨^ 从左往右
⑩| 从左往右
①&& 从左往右
②|| 从左往右
③?:从右往左
④=、+=、*=、/=、%=、&=、|=、^=、~=、<<=、>>=、>>>= 从右往左
注:在赋值运算中,赋值号两边数据的类型不同时,赋值号右边量或者表达式值的类型将自动转换为左边量的类型。如果右侧数据类型长度比左边长,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入的规则向前舍入。
在C++中,除了“自动转换”,还可以“强制类型转换”。格式为:
(类型名)(表达式)
(类型名)变量→加括号
第十课 格式控制
1.printf函数
① C++语言兼容C语言中的基本语句语法。scanf和printf是C语言中的输入输出函数(语句)。
②对于大数据的输入输出,使用scanf和printf,比C++中的输入输出流语句(cin和cout)效率更高、速度更快。
③ scanf和printf是标准库函数,使用前需要加上cstdio头文件。
常用的格式字符
①%d 以十进制形式输出带符号整数,正号(+)不输出
②%o 以八进制形式输出无符号整数,不输出前缀0
③%x %X 以十六进制形式输出无符号整数,不输出前缀0x
④%u 以十进制形式输出无符号整数
⑤%c 以字符形式输出一个字符
⑥%s 输出字符串
⑦%f ,%lf 以小数形式输出单、双精度数,隐含输出6位小数
⑨%e,%E 以指数形式输出实数
⑩%l 加在格式符d、o、x、u前,用于长整型数据
使用说明:
1)输出整数形式可以用%d或%md,m为指定的输出字符的宽度,输出数据右对齐。例如,“printf(“a=%d,a=%4d,a,a);”若a=1,结果为“a=1,a=1”。
2)输出长整型可以用%ld,一个int数据可以用%d或%ld格式输出。
3)输出字符串用%s,如 “printf(”%s",“helo”);”。
4)“%ms”,输出的字符串占m列,如字符串本身长度大于m,则突破m的限制,将字符串全部输出;若串的长度小于m,则左补空格。
5)“%-ms”,若串长小于m,则在m列范围内,字符串向左靠,右补空格。
6)“%m.ns”,输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
7)“%-m.ns”,m、n含义同上,n个字符输出在m列范围的左侧,右补空格,如果n>m,则m自动取n值,即保证n个字符正常输出。8)“%m.nf,输出浮点数,占m列,其中有n位小数,如果数值长度小于m,则左补空格。
9)“%-m.nf,同上,只是使输出的数值向左端靠齐,右端补空格。
2.scanf函数
格式:(格式控制字符串,地址表列)
scanf的作用是输入指定形式的数据。地址表列可以是变量的地址,也可以是字符串的首地址。
例:
int a,b;
scanf("%d,%d,&a,&b");
表示先在内存中各开辟4字节的空间给a和b,当遇到 scanf语句时,就把键盘上输入的2个数依次存入a、b所在的空间(及地址中)。“&a”表示取a变量的地址,“&”称为取地址符。简而言之,就是先找地址后放值。
使用 scanf函数时,需要注意以下问题:
1)如果在格式控制字符串中有其他字符,则运行程序输入数据时,对应的位置也要输入这些相同的字符。
例:scanf("%d, %d", &a,&b);
键盘输入应该是“3,4”,而不能是“3 4”
2) scanf函数输入时可以过滤掉不想读入的字符。
例:scanf("%d+%d+%d,&a,&b,&c);
键盘输入“1+2+3”,则 scanf可以无视“+”,使得a、b、c的值分别为1、2、3。
再如:scanf("%3d %3d %2d",&m,&n);
键盘输入“113 118 69”,则m、n的值分别为113、69,因为“
”表示跳过相应数据。
3.scanfprintf与cin、cout的比较
cin是输入流,cout是输出流,重载了“>>”“<<”运算符,包含在头文件< iostream>中。
cin代表标准输入设备,使用提取运算符“>>”从键盘取得数据,送到输入流对象cin中,然后送到内存。cin是自动判断变量类型,比如一个char数据只能用默认的char方法取数据。
cout先把要输出的东西存入缓冲区,遇到“endl”或者“ return0”再输出并刷新缓冲区,导致效率降低。
scanf是格式化输入, printf是格式化输出,包含在头文件< cstdio>中。
因为 scanf是用指针操作的,没有类型安全机制,比如对于一个char类型数据,就可以用%f”获得输入,而不会报错,但在运行时会出现异常。 scanf函数取数据时遇到回车、空格、TAB就会停止。
printf输出效率比较高,但是编写代码相对而言麻烦一些。取a变量的地址,“&”称为取地址符。简而言之,就是先找地址后放值。
使用 scanf函数时,需要注意以下问题:
1)如果在格式控制字符串中有其他字符,则运行程序输入数据时,对应的位置也要输入这些相同的字符。
例:scanf("%d, %d", &a,&b);
键盘输入应该是“3,4”,而不能是“3 4”
2) scanf函数输入时可以过滤掉不想读入的字符。
例:scanf("%d+%d+%d,&a,&b,&c);
键盘输入“1+2+3”,则 scanf可以无视“+”,使得a、b、c的值分别为1、2、3。
再如:scanf("%3d %3d %2d",&m,&n);
键盘输入“113 118 69”,则m、n的值分别为113、69,因为“
”表示跳过相应数据。
3.scanfprintf与cin、cout的比较
cin是输入流,cout是输出流,重载了“>>”“<<”运算符,包含在头文件< iostream>中。
cin代表标准输入设备,使用提取运算符“>>”从键盘取得数据,送到输入流对象cin中,然后送到内存。cin是自动判断变量类型,比如一个char数据只能用默认的char方法取数据。
cout先把要输出的东西存入缓冲区,遇到“endl”或者“ return0”再输出并刷新缓冲区,导致效率降低。
scanf是格式化输入, printf是格式化输出,包含在头文件< cstdio>中。
因为 scanf是用指针操作的,没有类型安全机制,比如对于一个char类型数据,就可以用%f”获得输入,而不会报错,但在运行时会出现异常。 scanf函数取数据时遇到回车、空格、TAB就会停止。
printf输出效率比较高,但是编写代码相对而言麻烦一些。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值