《C实验1知识点总结1.docx》由会员分享,可在线阅读,更多相关《C实验1知识点总结1.docx(4页珍藏版)》请在第一文库网上搜索。
1、数据在计算机的存储以二进制补码表示。原码补码各种数据类型及存储方式原码补码题目通常和类型转换放在一起使用。大端小端根据计算机系统的不同。基本类型的存储方式分为大端模式和小端模式。小端模式:如intekarmo特点:低字节在低地址。大端模式:如POWerPc。特点:高字节在低地址。思考:如何判断一个系统采用大端模式还是小端模式?转义字符,大端小端。变量的含义,左值:等号二的左边,代表的是一个地址例如:inta;a=3a代表变量a对应的内存的地址,该表达式的意思是:把整形常量3写在a对应的地址开始的四个字节里。右值:等号二的右边,代表的是一个地址里的值。intc;c=aa代表变量a的对应的内存的值
2、。该表达式的意思是:把a对应的地址开始的4个字节的内容取出,赋给c对应的的地址开始的4个字节里变量的声明和定义,及初始化定义是一种特殊的声明,它创建了一个对象;声明简单地说明了在其他地方创建的对象的名字,它允许你使用这个名字。让我们回顾一下这两个术语:定义只能出现在一个地方确定对象的类型并分配内存,用于创建新的对象,例如:intmy_array10024;声明可以多次出现描述对象的类应,用于指代其他地方定义的对象(例如在其他文件里)例:externintmy_array口4;只要记住下面的内容即可分清定义和声明:声明相当于普通的声明:他所说明的并非自身,而是描述其他地方创建的对象。定义相当于特
3、殊的声明:它为对象分配内存。extern对象是声明,告诉编译器对象的类型和名字,对象的内存分配则在别处进行。(注:这里所说的对象与C+里的对象无关,这里的对象只是跟链接器有关的“东西”,比如函数和变量。)变量的初始化:在定义时(即为对象分配内存时)提供一个值。比如:inta=3;是初始化。下面第二条语句是赋值。比如:inta;a=3;这里区分开来是为了让大家明白,对于有些类型初始化和赋值操作不同。比如:数组inta3=1,2,3;可以。却不能这么做inta3;a=1,2,3);结构体structAinta,charb;structAa=12,m;可以。却不能这么做StructAa;a=12,m
4、,;后面在指针和结构体时,会讲解复杂声明的分析。数的进制八进制十进制十六进制的表示只是书写方式的不同,在内存里都是二进制来表示的。比如常量:023190x13在机器里的表示相同。printf和scanf等getchar()PUtChar()基本输入输出函数printf和scanf练习自增自减运算符,自增自减的分析inta=3;intb;b=a+;基本运算符,运算符的优先级SiZeofSiZeof是一个运算符,用于判断变量类型占用多少字节在编译时其值就已经求出来,即根据类型来判断它占用的内存大小SiZeOf的使用练习inta=3,b=4;sizeofa+b=shorta=1;printf(4t%
5、dnM,sizeofa+);a=char*p=NU11;Printf(%dn,sizeof(*p);常量:保存在只读区,值不能被修改。浮点数常量如:3.14是以doub1e型保存的。同时,由前面介绍的浮点数的存储方式可知,计算机里并不能精确地表示浮点数。例如3.14表示一个约等于3.14的浮点数。整数常量如-35、19是以int型保存的。字符常量如W是以int型保存的。字符串常量是以字符0结尾的char型数组保存的。例题:sizeof(1.0)=sizeof(1)=sizeof(a)=SiZeOf(ab)=运算中类型转换及练习隐式类型转换:当操作符的操作数类型不一致是会发生类型转换。它负责把两
6、个不同的操作数类型转换成同一种普通类型,转换后的类型通常就是结果类型。为什么有类型转换?整形提升:charShOrtint和位段类型(无论Signed或UnSigned)以及枚举类型将被提升为it,前提是int能够完整地容纳原来的数据,否则将被转换为unsignedintof1oat类型在表达式中转换为doub1e类型。若有整形和浮点数,则转换为doub1e类型。隐式类型转换总是向着精度更高,长度更长的方向转换。ANS1C表示,如果编译器能够保证运算结果一致,也可以省略类型提升这通常出现在表达式中有常量操作数的时候。比如:charc1,c2;c1=c1+c2;根据整形提升规则,先把每个变量的值
7、提升为int的长度,再执行加法,然后再对运算符进行裁剪。如果两个char的加法不会发生溢出,那么实际执行时可以省略类型提升。又如,f1oatf1,f2;doub1ed;f1=f2*d;如果编译器可以确定用f1oat进行运算的结果跟转换为doub1e后进行运算的结果一样,那么也可以使用f1oat来进行乘法运算。对于整形的赋值浮点数到整型的转换会去掉小数部分,即取整后赋给整形变量。对于运算里既有有符号也有无符号,首先看,有符号能否表示所有的无符号的值,若可以,则都变成有符号的类型,否则都变成无符号类型。同类型,有符号和无符号之间赋值,是内存拷贝,即内存内容一样,只是一个当做有符号数来解读,一个当做
8、无符号数解读。inta=-1;unsignedintb=a;printf(ua%xb%xn,a,b);长的赋给短的类型,直接进行截断处理。短的赋给长的类型,根据短的类型是否为有符号的。若为有符号的,符号位扩展,赋给长类型。若为无符号的,高字节填0,赋给长类型的intmain()(inta=0x1280;charb=a;unsignedcharch=a;charc=128;unsignedchard=128;intm=c;intn=d;*用Printf打印上面的值*/returnO;)例如:intmain()(inta=-20;unsignedcharch=6;if(a+chO)printf(t
9、a+chOn);e1sePrintf(a+ch=On);returnO;)例如:intmain()chara1IOOO;inti;for(i=0;i1000;i+)ai=-1-i;printf(4%dn,str1en(a);returnO;)强制类型转换,即显式类型转换。inta=3;doub1eb=(dou1e)a;把a的值转换成doub1e类型的格式然后赋值给bo注意:无论隐式还是显式类型转换都没有改变原类型(如这里的变量a)的内容。另一个会发生隐式类型转换的地方就是参数传递。在ANS1C中,若没有使用适当的函数原型(即声明),类型提升便会发生。在被调用函数的内部,提升后的参数被裁减为原先
10、声明的大小。这就是为什么单个的Printf格式符字串d能适用于几个不同类型,shortchar或int而不论实际传递的是上述那种类型。因为对于d,printf总是从内存中取4个字节,并按有符号整形输出。这是因为在缺少更多信息的情况下(Printf的形参是可变参数),Printf假定它是int类型的。因此对于Iongkmg型,除非使用1d,否则不能打印出正常的信息。下次课循环、分支跳转语句、逗号运算符和条件运算符。标准输入输出函数的缓冲区介绍。C语言语句分析,一些逻辑思维题目练习,各种基本排序和查找算法的实现函数定义及返回值return取地址符&函数参数值传递和地址传递,全局变量和StatiC变量,static函数和内联函数进程的内存布局,函数调用过程中的栈结构,递归函数的基本原理及函数调用分析代码书写规范,递归函数的调用分析与实践