还剩15页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
语言基础知识总结CC语言基础知识总结总结是对取得的成绩、存在的问题及得到的经验和教训等方面情况进行评价与描述的一种书面材料,它可以促使我们思考,因此好好准备一份总结吧如何把总结做到重点突出呢?以下是店铺整理的c语言基础知识总结,希望能够帮助到大家主要内容
1.C数据类型
2.简单的算术运算和表达式
3.键盘输入和屏幕输出
4.选择控制结构总结风格分条罗列,主要是知识点,有例题不多5彳盾环控制结构
一、C数据类型LC语言处理两种数据常量和变量
5.常量整形常量、实型常量、字符常量、字符串常量、枚举常重
6.整形常量正整数、负整数、零eg:10,-30,
07.实型常量实数、小数、浮点数eg:
3.14,-
0.56,
18.
08.字符常量字符型常量、用单引号括起来的任意字符eg:x X,
99.字符串常量用双引号括起来的一个或多个字符eg:x HelloY7810在C程序中,整型常量可以用十进制、八进制、十六进制形式表示,但编译器都会自动将其转换成二进制存储11整型常量的类型长整型、短整型、有符号、无符号12不同进制的整型常量的表示形式)1十进制0〜9数字组合,可带正负号eg:256,-128,0,4-7)2八进制0开头,后面跟0〜7数字组合eg:021,-017float a,b,c,s,area;printfInput a,b,c:;s=a+b+c/2;area=floatsqrts*s-a*s-b*s-c;printfarea=%f,area;
21.赋值运算符的左侧不能出现表达式,变量与变量之间可以赋值例1:若有定义inta,b,c;下列表达式中哪一个是合法的C语言赋值表达式C、DAa=7+b=c=7Ba=b++=c=7Ca=b=7,c=12Da=3,b=a+5,c=b+2〃A.7+b表达式不能做左值B.b++表达式不能做左值C.逗号表达式a=12D.依次赋值例2:下面不正确的赋值语句是BAa=++a Ba=b++=10Ca+=b Da=la〃D.算术运算符优先级高于赋值运算符,先算la再将其结果赋给a例3:若有下列定义int a=3,b=2,c=l;以下选项错误的赋值表达式是AAa=b=4=3Ba=b=c+1Ca=b=4+c Da=l+b=c=4〃A.先计算圆括号里的值等于4,然后按照赋值表达式的顺序从右向左计算,将3赋值给4这是不对的,即赋值号左侧只能是变量,不能出现表达式b=4
三、键盘输入和屏幕输出
1.字符常量把字符放在一对单引号内,适用于多数可打印字符
2.转义字符以反斜线开头,也是放在一对单引号内,适用于控制字符如回车符,换行符
3.常用的转义字符1一换行8a一响铃报警提示音2—回车不换行9—一个双引号3一空字符10——个单引号4—水平制表11—一个反斜线5V—垂直制表12—问号6—退格13ddd—1至I」3位八进制ASCII码值所代表的字符7f—走纸换页14xhh—1至I」2位十六进制ASCII码值所代表的
4.,是将光标移到下一行起始位置,是将光标移到当前行的起始位字符
5.,是水平制表符,相当于按下Tab键,每次按下Tab键并不是从当前光标位置向后移动一个Tab宽度,而是移到下一个制表位实际移动的宽度视当前光标位置距相邻的下一个制表位的距离而定
6.制表位,屏幕上的一行被分为若干个域,相邻域之间的交接点称为制表位,每个域的宽度就是一个Tab宽度,多数习惯上为
47.当转义序列出现在字符串中时,是按单个字符计数的
8.一个整形数在内存中是以二进制形式存储的,而一个字符在内存中也是以其对应的ASCII码的二进制形式存储的,但char型数据在内存中只占一个字节,而int型数据在16位系统中占2个字节,32位系统占4个字节
9.在ASCII码取值范围内,char型数据可以和int型数据进行混合运算,char型数据也能以int型输出,直接输出其对应的ASCII码的十进制值
10.字符的输入/输出1get和put是C标准函数库中专门用于字符输入/输出的函数,功能是只能输入/输出一个字符2例从键盘输入一个大写英文字母,将其转换为小写字母显示在屏幕上#include()void main(char ch;)ch=get;〃键盘输入一个字符,再按回车表示输入结束,字符存入)变量ch,注意get没有参数,直接返回读入的字符ch=ch+32;)putch;〃第二次按回车,将显示转换后的结果)put);〃注意put内一定要有参数,参数就是待输出的字符,可以是可打印字符,也可是转义字符)
11.数据的格式化屏幕输出)()1函数printf的一般格式:printf(格式控制字符串);或者printf(格式控制字符串,输出值参数表);)2格式控制字符串包括格式转换说明符,需要原样输出的普通字符)3函数printf的格式转换说明符%d-输出带符号十进制整数,整数符号省略%u—输出无符号十进制整数%o—输出无符号八进制整数,不输出前导符0%x—输出无符号十六进制整数(小写),不输出前导符Ox%X—输出无符号十六进制整数(大写),不输出前导符Ox%c—输出一个字符%s—输出字符串%f一以十进制小数形式输出实数,包含单,双精度,隐含6位小数,但并非全是有效数字,单精度有效7位,双精度16位%e-以指数形式输出实数(小写e表示指数部分),小数点前有且仅有一位非数字%E—以指数形式输出实数大写E表示指数部分%g—自动选取f或e格式中宽度较小的一种使用,不输出无意义的0%%—输出%4输出值参数表需要输出的数据项的列表,可以是变量或表达式,逗号隔开,类型与格式转换说明符相匹配5每个格式转换说明符与输出值参数表中的输出值参数一一对应,没有输出值参数,格式控制字符串就不需要格式转换说明符6例从键盘输入一个大写英文字母,将其转换为小写字母和其十进制ASCII码值显示在屏幕上#includevoid maincharch;printfPlease entera key:;ch=get;ch=ch+32;printf%c,%d,ch,ch;//printf%c ch=putch,printf,=put}7函数printf中的格式修饰符在%和格式符中间插入格式修饰符,用于输出格式的微调,如指定输出域宽、精度、左对齐等英文字母I一修饰格式符d o,x,u时,用于输出long型数据,英文字母L—修饰格式符f,e,g时,用于输出long double型数据英文字母h—修饰格式符d,o,x时,用于输出short型数据输出域宽m—m为整数,输出时占m歹I」,若m0,当数据宽度小于m时,域内右靠齐,左补空格,当数据宽度大于m时,修饰符失效,按实际宽度输出,若m有前导符0,左边多余位补0;若m0,输出数据在域内左靠齐显示精度.n—n为大于等于0的整数,精度修饰符位于最小域宽修饰符之后,由圆点和整数构成,对于浮点数,用于指定输出的浮点数小数位数;对于字符串,用于指定从字符串左侧开始截取的子串字符个数)8使用const常量定义pi,编程从键盘输入圆的周长和面积,使其输出数据保留两位小数#includevoid mainconstdouble pi=
3.14159;double Gcircum^rea;printfPlease enterr:;scanf%lf,r;circum=2*pi*r;area=pi*r*r;printf输出没有宽度和精度的值:;printfcircum=%f,area=%f”,circum,area;printf输出没有宽度和精度的值:printfcircum=%
7.2f,area=%
7.2f,circum,area;〃域宽为7,占7个字符宽度,小数点也算一个字符,精度为2,小数点后保留2位)
12.数据的格式化键盘输入)()1函数scanf的一般格式scanf(格式控制字符串,参数地址表);)2格式控制字符串包括格式转换说明符,分隔符)3格式转换说明符以%开始,以格式字符结束,用于指定各参数的输入格式)()4函数scanf的格式转换说明符%d—输入十进制整数%一输入八进制整数%x-输入十六进制整数%c—输入一个字符,空白字符(包括空格、回车、制表符)也作为有效字符输入%S—输入字符串,遇到第一个空白字符包括空格、回车、制表符时结束%f或%-输入实数,以小数或指数形式输入均可®%%—输入一个%5参数地址表由若干变量的地址组成的列表,用逗号分隔6函数scanf中的格式修饰符在%和格式符中间插入格式修饰符英文字母I—加在格式符d,o u之前,用于输入long型数据;加在/X/f,e之前,用于输入double型数据英文字母L—加在格式符f,e之前,用于输入long double型数据英文字母h—加在格式符d,o,x时,用于输入short型数据输出域宽m-m为正整数,指定输入数据的宽度,系统自动按此宽度截取所需数据显示精度.n—n为0或正整数,seanf没有精度格式修饰符,输入时不能规定精度忽略输入修饰符*—表示对应的输入项在读入后不赋给相应的变量7函数scanf输入数值型数据时,被认为输入结束的几种情况遇空格符、回车符、制表符;达到输出域宽;遇非法字符输入8如果函数scanf的格式控制字符串中存在除格式转换说明符以外的其他字符,必须将这些字符原样输入#includevoid mainint a,b;scanf%d%d,a,b;〃以空格作为分隔符,等价于scanf%d%d,a,b,等价于scanf%d%d,a,b,printfa=%d,b=%d”,a,b;〃实际输入时,空格、回车符、制表符都可作为分隔符,即输入12空格3412回车3412制表符34均可,#includevoid maininta,b;scanf%d,%d,a,b;〃输入时必须以逗号作为分隔符,即只能输入12,34printfa=%d,b=%d,a,b;#includevoid maininta,b;scanf匕=%d,b=%d,a,b;〃输入时必须将匕二和b二原样输入,即只能输入:a=12,b=34printfa=%d,b=%d,a,b;下载文档)()()3十六进制Ox OX开头,后跟0~9,a~f A~F数字组合eg:0xl2,-0xlF
13.不同类型的整形常量的表示形式)1有符号整型常量默认int型定义为有符号整数,无需signedeg:10,-30,0)>2无符号整形常量常量值后跟u或U,只能表示=0的数eg:30u256Uz)3长整型常量常量值后跟I或L eg:-256l,1024L)4无符号长整型常量:常量值后跟LU、Lu、IU、lu eg:30lu
14.C程序中,实型常量两种表示形式小数、指数
15.不同形式的实型常量的表示形式)1十进制表示形式数字和小数点组成,必须要有小数点,整数部分可省略eg:
0.123,-
12.35,.98)2指数形式e或E代表以10为底的指数,e左边是数值部分(有效数字,可以是整数、小数,不能省略),e右边是指数部分(必须是整数形式)eg:
3.45e-
616.实型常量有单精度和双精度之分,无有符号和无符号之分
17.不同类型的实型常量表示形式)1单精度实型常量常量值后跟F或f eg:
1.25F,
1.25e-2f)()2双精度实型常量double:实型常量默认按双精度处理eg:
0.123,-
12.35,.98)()3长双精度实型常量long double:常量值后跟L或I eg:
1.25L
18.变量在程序执行过程中可以改变的量
19.变量在必须先定义后使用,定义时需要声明变量的类型和变量名,一般形式类型关键字变量名;
20.关键字是C语言预先规定具有特殊意义的单词,类型关键字用于声明变量的类型()
21.标准C语言编写的程序都是以main作为开头,指定了C程序执行的起点,在c程序中只能出现一次,称为主函数,
22.C程序总是从main函数开始执行,与他在程序中的位置无关main函数主体部分称为语句,用{}括起来,一般C语句以;结束
23.变量的类型决定了编译器为其分配内存单元的字节数、数据在内该类型变量合法的取值范围以及该类型变量可参与的运算种类存单元中的存放形式、
24.变量名是用户定义的标识符,用于标识内存中具体的存储单元,存放的数据称为变量的值
25.新数据存放于存储单元时,旧数据将会被修改,反应变量的值是可以改变的
26.变量名的命名规则)1标识符只能由英文字母、数字、下划线组成)2标识符必须以字母或下划线开头)3不允许使用C关键字为标识符命名)4标识符可以包含任意多个字符,但一般会有最大长度限制,预编译器有关,一般不会超过,最好不超过8个字符注意标识符区分大小写eg:x y3Jmax ELSEX A_to_B(合法)eg:7x int#No badone re-input(不合法)
27.标准C规定所有变量必须在第一条可执行语句之前定义
28.在同一条语句中可以同时定义多个相同类型变量,多个变量之间用逗号分隔,没有顺序要求
29.在使用标准输入/输出函数时,必须在程序开头加上编译预处理命令
30.中stdio为头文件,std是standardj为input,o为output,h为head
31.编译预处理命令include的作用将在输入/输出函数的头文件stdio.h包含到用户源文件中
32.%d按十进制整数个格式输出,%f按十进制小数格式输出,一般输出6位小数,%c输出一个字符,换行,双引号内字符原样输出
33.不同类型的数据在内存中占用不同大小的存储单元,他们所能表示的数据的取值范围各不相同,不同类型的数据表示形式及其可以参与的运算种类也不同
34.定义整型变量时,只要不指定为无符号型,其隐含类型为有符号型,signed通常省略不写
35.C程序中每个变量的值都是按字节编址,都被存储在内存中特定的存储单元中,这个存储空间实际是一个线性地址表,即每个字节的存储空间对应一个唯一的地址
1.11个字节等于8个二进制位,即8个位为一个字节,一个字节可以表示的整数最小为0,最大255,即8个位可以表示0-255之间的数,一个二进制位的值只能是0或
134.同种类型在不同的平台所占字节数不同,要计算数据类型所占内存空间的字节数需要用sizeof运算符
35.sizeof是C语言关键字,不是函数名,sizeof变量名浒算一个变量所占内存的字节数
36.计算不同类型运算符的表达式时,要考虑运算符的优先级和结合性
37.正数的反码、补码与原码都相同,负数的补码等于反码加
138.在计算机内存中负数都是用补码来表示
39.对于实数,无论小数海曙指数形式,在计算机内存中都采用浮点形式来存储
40.浮点数分为阶码、尾数两部分,实数N=S*powr,j,S为尾数无论正负,规定用存小数,j为阶码无论正负,必须是整数,r是基数eg:
10.0111=
0.100111*pow2,
1041.阶码所占位数决定实数的取值范围,尾数所占位数决定实数的精度,尾数的符号决定实数的正负,阶码和尾数的字节大小与编译器有关
42.float型变量能接收实型常量的7位有效数字,double型变量能接收16位
43.运算符的优先级单目运算〈算术运算〈关系运算〈逻辑运算条件运算赋值运算逗号运算
44.素数又称质数,指在大于1的自然数中,除1和本身不能被其他自然数整除的数
45.合数指在自然数中除1和本身外还能被其他自然数整除的数
46.因子所有能整除这个数的数,不包括自身,但包括
147.闰年能被4整除但不能被100整除,或能被400整除
二、简单的算术运算和表达式L条件运算符是C语言提供的唯一一个三元运算符,C语言中没有幕运算符48只有计算相反数是一元运算符,其余运算符都是二元运算符49一元运算符也叫单目运算符,二元运算符也叫双目运算符,三元运算符也叫三目运算符50整数除法的结果是整数,浮点数除法的结果是浮点数51求余运算限定参与运算的两个操作数必须为整型,余数的符号与被除数的符号相同,不能对两个实型数进行求余运算52所有的算术运算符中只有一元的去相反数运算符为右结合,其余的结合性都为左结合53同一优先级的运算符进行混合运算时,从左向右依次进行54运算符的优先级单目运算〉算术运算〉关系运算〉逻辑运算〉条件运算赋值运算逗号运算55计算并输出一个三位整数的个位、十位、百位数字之和#includevoid mainintx=321;inta,b,c,sum;a=x%10;//a=lb=x/10%10;//b=2c=x/100;//c=3sum=a+b+c;printfa=%d,b=%d,c=%d sum=%d1abc,sum;
56.涉及算术运算的复合赋值运算符有5个
57.增1运算符也称自增运算符,减1运算符也称自减运算符,都是一元运算符,只有一个操作数必须是变量不能是常量或表达式58启增自减运算符作为前缀时,先执行加1或减1然后使用;自增自减运算符作为后缀时,先使用再执行加1或减1;
13.考虑优先级与结合性的实例《》m=-n++《=》m=-n++=m=-n,n=n+l;〃正面-和++都是一元运算符,优先级相同,此时要考虑结合性,结合性都是右结合的,所以先算++后算-〃反面如果等价m=-n++就不合法了,因为表达式不能进行自增操作
14.scanf函数和printf函数都是C的标准输入/输出函数,为取地址运算符
15.宏常量与宏替换1在程序中直接使用的常数称为幻数,将幻数定义为宏常量或const常量是为了提高程序的可读性和可维护性2宏常量也称符号常量,没有数据类型,编译器不对其进行类型检查,只进行字符串替换3宏定义一般形式#define标识符字符串标识符被称为宏名,宏名与字符串之间可有多个空白符,不加等号,结尾不加分号4宏常量是由宏定义编译预处理命令来定义,宏名替换成字符串的过程称为宏替换,宏替换不做任何语法检查5当宏定义是一个表达式时,调用时,是一个数就可以直接带入,而是表达式也要看成是一个数代进宏定义表达式中,而看成一个数这就要求把调用的数加上圆括号,为了减少不必要的错误,最好都加上圆括号)6宏替换的过程是将宏名原样替换成字符串,而不是直接计算出值,所以要用调用后的结果参与其他运算就需要把调用的结果加上圆括号)7例题#include#define N2//N=2#define MN+1〃M=2+1#define NUM2*M+1//NUM=2*2+1+1=6void maininti;fori=l;i=NUM;i++;printf%d,i;〃执行完空循环,i=7;〃i=6printf%d,i;8例题:#include#define fxx*xvoid mainint b;b=f4+4;〃b=4+4*4+4=24,解释见5printfb=%d,b;9例题:#include#define fxx*x voidmainintb;b=f4+4/2+2;〃b=4+4*4+4/2+2=21解释见6printfb=%d,b;10例题#include#define fxx*xvoid mainintb;b=f4+4;//b=4+4*4+4=64printfb=%d,b;11例题#include#define fxx*xvoid mainintb;b=f4+4/2+2;//b=4+4*4+4/2+2=16printfb=%d,b;
16.const常量1const常量只能在定义时赋初值,因为编译器将其放在只读存储区,不允许在程序中修改2const常量的定义一般形式const类型名标识符二字符串;〃将标识符声明为具有该数据类型的const常量3const是一种类型修饰符,const常量具有数据类型,编译器要对其进行类型检查
17.表达式中的自动类型转换1表达式中,操作数类型相同,运算的结果类型与操作数类型相同2表达式中,操作数类型不相同,C编译器自动将所有操作数进行类型提升,转换成同一类型,所占字节最大,再计算
18.赋值中的自动类型转换1赋值运算符左侧变量与右侧表达式类型不同时,发生自动类型转换右侧表达式的值转换成左侧变量的类型
19.强制类型转换1强制类型转换运算符是一元运算符2强制类型转换也称强转,是将表达式的值转换为任意类型,并不改变变量本身的数据类型3强转一般形式类型表达式4演示强制类型转换运算符的使用#includevoid mainintm=5;printfm/2=%d,m/2;//m=2printffloatm/2=%f,floatm/2;//m=
2.000000printffloatm/2=%f,floatm/2;//m=
2.500000printfm=%d,m;〃m=5,只是将m强转为实型数据,并不改变m的数据类型}
20.常用的标准数学函数1使用C标准数学函数,要在程序开头加上编译预处理命令#include2例已知三角形三边长为a,b,c,计算三角形的面积#include#includevoid main。