


版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、C语言概述:1) 1、为什么学习C语言.C的起源和发展.C的特点优点代码量小速度快功能强大缺点危险性高开发周期长可移植性不强.c的应用领域主要是系统领域.c的重要性2、怎样学习C语言3、学习的目标了解程序语言及发展历史熟练掌握c语言的语法规则掌握简单的算法理解面向过程的思想,这非常有助于将来对面向对象思想的学习能看懂程序会调试程序掌握将大问题转化为一系列小问题来求解的思想为学习C+、数据结构、c#、java打下良好的基础4、常见的学习问题1、学习java为什么建议先学习C语言2、没学过电脑专业的课程能够学懂C语言3、英语和数学不好能学好C吗32个关键词:有系统定义,不能重做其他定义autobr
2、eakcasecharconstcontinuedefaultdodoubleelseenumexternfloatforgotoifintlongregisterreturnshortsignedsizeofstaticstructswitchtypedefunsignedunsignedunionvoidvolatilewhile5、课程规划c语言简介第一讲、基本编程知识第二讲、数据类型第三讲、运算符和表达式第四讲、流程控制所有语言都一样的第五讲、函数表达出面向过程和面向对象的区别第六讲、数组第七讲、指针c语言的灵魂第八讲、变量的作用域和存储方式第九讲、扩展数据类型第十讲、专题:字符串的处
3、理进制转换补码动态内存分配java、数据结构必学综合应用:链表的使用x2=%fn",x1);else(printf("无解n");Helloword程序举例#include<stdio.h>intmain(void)(printf("欢送大家学习C语言!");return0;6、举例子:一元二次方程# include<stdio.h># include<math.h>intmain(void)(把三个系数保存到电脑中inta=1;/=不表示相等,表示赋值intb=2;intc=3;doubledelta;/d
4、elta存放的是b*b-4*a*cdoublex1;/存放一元二次方程的其中一个解doublex2;/存放一元二次方程的其中一个解delta=b*b-4*a*c;if(delta>0)(x1=(-b+sqrt(delta)/(2*a)x2=(-b-sqrt(delta)/(2*a)printf("该一元二次方程有两个解,x1=%f,x2=%fn”,x1,x2);elseif(delta=0)(x1=(-b)/(2*a);x1=x2;右边赋给左边printf("该一元二次方程有一个唯一解,x1=C语言编写的病毒举例:1、龌龊的程序:/*龌龊的程序/*include<
5、;stdio.h>include<windows.h>include<malloc.h>intmain(void)intc;inti;intj;Nihao:printf("1:死机n");printf("2:机房爆炸n");printf("请选择:");scanf("%d,&c");If(c=1)System("shutdown-s-t60”)elseif(2=c)printf("你太坏了我要惩罚你!n");for(j=0;j<10;+j)S
6、ystem("start");elseprintf("你敲错了,请重新输入!n")gotonihao;return0;2、内存泄露(占满内存)程序导致死机实例# include<stdio.h># include<malloc.h>intmain(void)while(1)int*p=(int*)malloc(1000);return0;5、cpu内存条vc+6.0操作系统之间的关系6、变量为什么必须初始化所谓初始化就是赋值的意思C语言编程预备知识1、cpu内存条硬盘显卡主板显示器之间的关系2、Helloworld程序如何运行起来
7、的1字节3、什么是数据类型基本类型数据整数整型int-4字节短整型shortint2字节长整型longint8字节浮点数【实数】单精度浮点数一一float4字节双精度浮点数double8字节字符char复合类型数据结构体枚举共用体已淘汰4、什么是变量变量的本质是内存中一段存储空间7、如何定义变量数据类型变量名=要赋的值;等价于数据类型变量名;变量名=要赋的值;举例子:inti=3;等价于inti;i=3;inti,j;等价于inti;intj;inti,j=3;等价于inti;intj;j=3;inti=3,j=5;等价于inti,j;i=5;j=5;inti,j;i=j=5;等价于inti,
8、j;i=5;j=5;8、什么是进制十进制就是逢十进一'二进制就是逢二进一生活中用到进制的例子:一周七天:七进制一年十二个月:十二进制一小时六十分钟:六十进制电脑中的数据:二进制进制转化:什么叫进制进制就是逢几进一我们说的N进制实际就是指逢N进一'我们的电脑只识别二进制人类最习惯使用的是十进制为了实际需要我们又建立了八进制和十六进制C语言规定八进制前要加0注意是零不是字母o,十六进制前要加0X或0x,十进制前什么都不加!在汇编中:在数字后加字母B表示二进制数,加字母O表示八进制数,加字母D表示十进制,加字母H表示十六进制。例:1011B为二进制数1011,也记为101121357
9、O为八进制数1357,也记为135782049D为十进制数2049,也记为2049仲3FB9H为十六进制数3FB9,也记为3FB9佑什么叫n进制十进制十个基数,逢10进一基数:0123456789二进制二个基数逢二进一基数:01八进制8个基数逢8进一基数:01234567十六进制16个基数逢16进一基数:0123456789abcdef或0123456789ABCDEF十进制D二进制B八进制0十八进制0x00001234567891011121314159、常量在c语言中如何表示的整数十进制:传统的写法十六进制:前面加0x或0X,是数字0加x八进制:前面加数字0浮点数:传统写法floatx=3
10、.2;/传统科学计数法floatx=3.2e3;/x的值是3200字符单个字符用单引号括起来'A'表示字符A'AB'是错误的"AB"是正确的字符串用双引号括起来"A"正确,因为"A"代表了'A''0'的组合10、常量以什么样的二进制代码存储在电脑中整数是以补码的形式转化为二进制代码存储在电脑中的实数是以IEEE754标准转化为二进制代码储存在电脑中的具体可参见末尾的穿插在课堂中的零散知识笔记字符的本质实际也是与整数的存储方式相同11、代码标准化代码的可读性更高【容易让别人
11、和自己看懂】是程序更不容易出错林锐高质量C/C+编程代码要成对的敲12、什么是字节字节就是存储数据的单位,并且是硬件所能访问的最小单位1字节=8位1K=1024字节1M=1024K1G=1024M买硬盘时的换算是以1000为单位的13、不同类型的数据之间相互赋值的问题暂不考虑inti=45;longj=102345;i=j;printf("%d%dn”,i,j);floatx=6.6;doubley=8.8;printf("%f%lfn",x,y);14、什么是ASCIIASCII不是一个值,而是一种规定,ASCII规定了不同的字符是使用哪个整数值去表示它规定了&
12、#39;A'-65'B'-66'a'-97'b'-9815、字符的存储【字符本质上与整数的存储方式相同】基本的输入和输出函数的用法1. printf()-重点讲将变量的内容输出到显示器上四种用法printf("字符串n")printf("输出控制符",输出参数);printf("输出字符1输出字符2。",输出参数1,输出参数2,。);输出控制符和参数的个数必须对应printf("输出控制符非输出控制符",输出参数);输出控制符包含如下%d-int十进制%ld-
13、longint%c-char%f-float%lf-double%x(或者%X或者%#X)-int或longint或shortint%o-同上%s-字符串为什么需要输出控制符1. 01组成的代码可以表示数据也可以表示指令2. 如果01组成的代码表示的是数据的话,那么同样的01代码组合以不同的输出格式输出就会有不同的输出结果scanf()-Java中已经没有了两种用法:用法一:scanf("输入控制符”,输入参数);功能:将从键盘输入的字符转化为输入控制符所规定格式的数据,然后存入已输入参数的值为地址的变量中。用法二:scanf(-非输入控制符输入控制符”,输入参数);功能:将从键盘输
14、入的字符转化为输入控制符所规定格式的数据,然后存入以输入参数的值为地址的变量中非输入控制符必须原样输入如何使用scanf编写出高质量代码使用scanf之前最好先使用printf提示用户以什么样的方式来输入Scanf中尽量不要使用非输入控制符,尤其是不要用n应该编写代码对用户的非法输入做适当的处理【非重点】while(ch=getchar()!='n'continue;运算符算术运算符+-*/(除)(取余数)除法的运算结果和运算对象的数据类型有关,两个数都是int,则商就是int,假设商有小数,则截取小数部分;被除数和除数中只要有一个或两个都是浮点型数据,则商也是浮点型,不截取小
15、数部分。如:16/5=316/5.0=3.20000-13/4=-4-13/-3=43/5=05/3=1最经典的例题就是求s=1+1/2+1/3+1/4+1/5.+1/100的值。取余的运算对象必须是整数,结果是整除后的余数,其余数的符号与被除数相等。如:13%3=113%-3=1-13%3=-1-13%23=-133%5=3关系运算符>>=<<=!=(不等于)=(等于)逻辑运算法!(非)&&(并且)|(或)!真假!假真真&&真真真&&假假假&&真假假&&假假真|暇假|限真|限假|暇真真真假
16、C语言对真假的处理非零是真零是假真是1表示假使0表示&&左边的表达式为假右边的表达式肯定不会执行|左边的表达式为真右边的表达式肯定不会执行赋值运算符=+=*=/=-=优先级别算术>关系>逻辑>赋值附录一些琐碎的运算符知识自增自减三目运算符逗号表达式流程控制学习c语言的第一个重点什么是流程控制程序代码执行的顺序流程控制的分类顺序If(表达式)(语句A;语句B;此时if可以控制语句A和语句B由此可见:if默认只能控制一个语句的执行或不执行,如果想控制多个语句的执行或不执行就必须把这些语句用(括起来。if.else.的用法if.elseif.else.的用法格式:i
17、f(表达式1)A;elseif(表达式2)B;if(表达式3)C;elseD;选择定义某些代码可执行,也可能不执行,有选择的执行某些代码分类ifif最简单的用法格式:if表达式语句功能:1. 如果表达式为真,执行语句如果表达式为假,语句不执行if的范围问题重点1.if(表达式)语句A;语句B;解释:if默认只能控制语句A的执行或不执行if无法控制语句B的执行或不执行或者讲:语句B一定会执行2.2. C语言对真假的处理非零是真零就是假真用一表示3. 假用零表示if举例-求分数的等级if的常见问题解析空语句的问题if(3>2);等价于if(3>2);这是一个空语句2.if(表达式1)A
18、;elseB;是正确的if(表达式1);A;elseB;是错误的3.if(表达式1)A;elseif(表达式2)B;if(表达式3)C;elseD;即便表达式1和2都成立,也只会执行A语句4.if(表达式1)A;elseif(表达式2)B;if(表达式3)C;这样些语法不会错,但逻辑上有漏洞5.if(表达式1)A;elseif(表达式2)B;if(表达式3)C;else表达式4/7行D;这样写是不对的,正确的写法是:要么去掉7行的表达式4要么在7行的else后面加if6.if(表达式1)A;elseif(表达式2)B;if(表达式3)C;else表达式4;D;这样写语法不会错,但逻辑上是错误的
19、else表达式4;D;等价于else(表达式4);D;对任意三个数字进行排序:如果a>b则a与c比较a>c则输出aa<c则输出c否则b与c比较b>c则输出bb<c则输出c穿插在课堂中的零散知识笔记:如何看懂一个程序,分三步:流程每个语句的功能试数如何学习一些需要算法的程序【如何掌握1. 一个程序】尝试自己去编程解决它但要意识到大部分人都是自己无法解决的,如果解决不了,这时不要气馁2. 如果十五分钟还想不出来,此时我建议您就可以看答案了如果解决不了,就看答案关键是把答案看懂,这个要花很大的精力,也是我们学习的重点看懂一个程序要分三步:流程、每个语句的功能、试数3.
20、看懂之后尝试自己去修改程序,并且知道修改之后程序的不同输出结果的含义不建议看懂程序之后就立即自己敲程序照着答案去敲4. 调试错误不看答案,自己独立把答案敲出来5. 如果程序实在无法彻底理解,就把它背会,无法彻底理解的程序很少很少几乎没有强制类型转换格式:数据类型表达式功能:把表达式的值强制转换为前面所执行的数据类型例子:int4.5+2.2最终值是6float5最终值是5.0000000浮点数的存错所带来的问题float和double都不能保证可以把所有实数都准确的保存在电脑中例子:floati=99.9;printf("%fn”,i);因为浮点数无法准确存储,所以就衍生出来两个编程
21、问题举例:有一个浮点型变量x,如何判断x的值是否是零if(|x-0.0000001|<=0.0000001)是零else不是零为什么循环更新的变量不能定义成浮点型进制的复习:什么是进制逢n进一把r进制转成十进制十进制转成r进制十进制转r进制:除r取余,直至商为0,余数倒序不同进制所代表的数值之间的关系十进制的3981转化成十六进制是F8D十进制的3981和十六进制的F8D所代表的本质都是同一个数一些琐碎的运算符知识自增【或者自减】前自增-+i后自增-i+前自增和后自增的异同:相同:最终都使i的值加1不同:前自增整体表达式的值是i加1之后的值后自增整体表达式的值是i加1之前的值为什么会出现
22、自增代码更精练自增的速度更快学习自增要明白的几个问题1. 我们编程时应该尽量屏蔽掉前自增和后自增的差异自增表达式最好不要作为一个更大的表达式的一部分来使用或者说i+和+i单独成一个语句,不要把它作为一个完整的复合语句的一部分来使用三目运算符:A?B:C等价于If(A)B;elseC;逗号表达式格式:A,B,C,D功能:从左到右执行最终表达式的值是最后一项的值switch(很少用到,以后讲)把电梯程序看懂就行啦循环定义:某些代码会被重复执行分类for重点、用到最多、最难1格式:for(1;2;3)语句A;执行的流程【重点】单个for循环的使用多个for循环的嵌套使用for1;2;3/1for4;
23、5;6/2A;/3B;/4整体式两个语句,123是一个语句4是第二个语句for1;2;3for4;5;6(A;B;整体式一个语句for(7;8;9)for1;2;3(A;B;for4;5;6C;整体是一个语句2. 范围问题3. 举例:1+2+3+.+1001+1/2+1/3+.+1/100while执行的顺序格式:while(表达式)语句;与for的相互比较for和while可以相互转换for1;2;3A;等价于1;While2(A;3;1. while和for可以相互转化但for的逻辑性更强,更不容易出错,推荐多使用for举例从键盘输入一个数字,如果该数字是会文数,则返回yes,否则返回no
24、回文数:正着写和倒着写都一样比方:12112321都是回文数试数:>m=121sum=0*10+121%10=1m=m/10=12;>m=12成立sum=1*10+12%10=12m=12/10=1>m=1成立sum=12*10+1%10=121m=1/10=0>m=0不成立sum=val什么时候使用while,什么时候使用for没法说,用多了自然而然就知道了do.while格式:dowhile(表达式);do.while.并不等价于for,当然也不等价于while主要用于人机交互一元二次方程举例break和continuebreak很重要break如果用于循环是用来终
25、止循环break如果用于switch,则是用于终止switchbreak不能直接用于if,除了if属于循环内部的一个子句例子:for(i=0;i<3;+i)if(3>2)break;/break虽然是if内的语句,但break终止的却是外部的for循环printf("嘿嘿!n");/永远不会输出在多层循环中,break只能终止距离它最近的那个循环for(i=0;i<3;+i)for(j=1;j<4;+j)break;/break只能终止距离它最近的循环printf("同志们好!n”);在多层switch嵌套中,break只能终止距离它最近的
26、switch例子:intx=1,y=0,a=0,b=0;switch(x)/第一个switch(case1:switch(y)/第二个switch(case0:a+;break;/终止的是第二个switchcase1:b+;break;b=100;break;终止的是第一个switchcase2:a+;b+;break;printf("%d%dn”,a,b);/26行最终输出结果是:1100continue用的很少用于跳过本次循环余下的语句,转去判断是否需要下次循环for(1;2;3)(A;B;continue;/如果执行该语句,则执行完该语句后,会执行语句3,C和D都不会执行C;D
27、;while表达式(A;B;continue;/如果执行该语句,则执行完该语句后,会执行表达式,C和D都不执行。C;D;数组为什么需要数组为了解决大量同类型数据的存储和使用问题。为了模拟现实世界1. 数组的分类一维数组怎么定义一维数组为n个变量连续分配存储空间所有的变量数据类型必须相同所有变量所占的字节大小必须相等例子:inta5;一维数组名不代表数组中所有的元素,一维数组名代表数组第一个元素的地址有关一维数组的操作初始化完全初始化inta5=1,2,3,4,5;不完全初始化,未被初始化的元素自动为零inta5=1,2,3;不初始化,所有元素是垃圾值inta5;清零inta5=0;错误写法:i
28、nta5;a5=1,2,3,4,5;/错误只有在定义数组的同时才可以整体赋值,其他情况下整体赋值都是错误的inta5=1,2,3,4,5;a5=100;/error因为没有a5这个元素,最大只有a4inta5=1,2,3,4,5;intb5;如果把a数组中的值全部复制给b数组错误写法:b=a;/error正确的写法for(i=0;i<5;+i)bi=ai;赋值排序求最大/小值倒置查找插入删除二维数组Inta34;总共是12元素看,可以当做3行四列看待,这12个元素的名字依次是:a00a01a02a03a10a11a12a13a20a21a22a23aij表刀、第i+1行第j+1列的兀素i
29、ntamn;该二维数组右下角位置的元素只能是am-1n-1初始化inta34=1,2,3,4,5,6,7,8,9,10,11,12;inta34=1,2,3,4,5,6,7,8,9,10,11,12;操作输出二维数组的内容:inta34=1,2,3,4,5,6,7,8,9,10,11,12;inti,j;输出数组内容for(i=0;i<3;+i)for(j=0;j<4;+j)printf("%-5d",aij);/-号表示左对齐,5表示占5个光标的位置printf("n");对二维数组排序求每一行的最大值判断矩阵是否对称矩阵的相乘多维数组是否
30、存在多维数组不存在因为内存是线性唯一的n维数组可以当做每一个元素是n1维数组的一维数组比方:inta34;该数组是含有3个元素的一维数组只不过每一个元素都是4行5列的二维数函数【C语言的第二个重点】:为什么需要函数防止了重复性操作有利于程序的模块化什么叫做函数逻辑上:能够完成特定功能的独立的代码单元物理上:能够接受数据【当然也可以不接受数据】能够对接收数据进行处理能够将数据处理的结果返回【当然也可以不返回任何值前面定义成void】总结:函数是个工具,它是为了解决大量类似问题而设计的函数可以当做一个黑匣子如何定义函数函数的返回值函数的名字函数的形参列表(函数的执行体1. 函数定义的本质是详细描述
31、函数之所以能够实现某个特定功能的具体方法2. return表达式;的含义:1终止被调函数,向主调函数返回表达式的值2如果表达式为空,则只终止函数,不向主调函数返回任何值3break是用来终止循环和switch的,return是用来终止函数的例子:voidf()(return;/return只用来终止函数,不向被调函数返回任何值intf()(return10;第一:终止函数,第二:向主调函数返回10函数返回值的类型也称为函数的类型,因为如果函数名前的返回值的类型和函数执行体中的return表达式;中表达式的类型不同的话,则最终函数返回值的类型以函数名前的返回值类型为准例子:intf()(函数的分
32、类有参函数和无参函数有返回值函数和无返回值函数库函数和用户自定义函数值传递函数和地址传递函数普通函数和主函数main函数一个程序必须有且只能有一个主函数主函数可以调用普通函数普通函数不能调用主函数普通函数可以相互调用主函数是程序的入口,也是程序的出口注意的问题函数调用和函数定义的顺序如果函数调用写在了函数定义的前面,则必须加函数前置声明函数前置声明:告诉编译器即将可能出现的假设干个字母代表的是一个函数告诉编译器即将可能出现的假设干个字母所代表的函数的形参和返回值的具体情况函数声明是一个语句,末尾必须加分号对库函数的声明是通过#include库函数所在的文件的名字.h>来实现形参和实参个数
33、相同位置一一对应数据类型必须相互兼容如何在软件开发中合理的设计函数来解决实际问题一个函数的功能尽量独立,单一多学习,多模仿牛人的代码函数是C语言的基本单位,类是Java,C#,C+的基本单位常用的系统函数doublesqrt(doublex);求x的平方根intabs(intx)求x的绝对值doublefabs(doublex)求x的绝对值专题:递归可以参见数递结构视频变量的作用域和存储方式:按作用域分:全局变量在所有函数外部定义的变量叫全局变量全局变量使用范围:从定义位置开始到整个程序结束局部变量在一个函数内部定义的变量或者函数的形参都统称为局部变量voidf(inti)intj=20;I和
34、j都属于局部变量局部变量使用范围:只能在本函数内部使用注意的问题:全局变量和局部变量命名冲突的问题在一个函数内部如果定义的局部变量的名字和全局变量名一样时,局部变量会屏蔽掉全局变量按变量的存储方式静态变量自动变量寄存器变量指针:指针的重要性表示一些复杂的数据结构快速传递数据,减少了内存的耗用【重点】使函数返回一个以上的值【重点】能直接访问硬件能够方便的处理字符串是理解面向对象语言中引用的基础总结:指针是c语言的灵魂指针的定义地址内存单兀的编号从零开始的非负整数范围:4G【04G-1】指针指针就是地址,地址就是指针指针就越是内存单兀的编号指针变量是存放地址的变量指针和指针变量是两个不同的概念但是
35、要注意:通常我们表达时会把指针变量简称为指针,实际他们含义并不一样1. 指针的本质就是一个操作受限的非负整数指针的分类基本类型指针int*p;/p是变量的名字,int*表示p变量存放的int类型变量的地址/int*p;不表示定义了一个名字叫做*p的变量/int*p;应该这样理解:p是变量名,p变量的数据类型是int*类型/所谓int*类型实际就是存放int变量地址的类型inti=3;intj;1. p=&i;/*p保存了i的地址,因此p指向ip不是i,i也不是p,更准确的说:修改p的值不影响i的值,修改i的值也不会影响p的值如果一个指针变量指向了某个普通变量,则*指针变量就完全等同于普
36、通变量例子:如果p是个指针变量。并且p存放了普通变量i的地址,则p指向了普通变量i*p就完全等同于i或者说:在所有出现*p的地方都可以替换成i,在所有出现i的地方都可以替换成*p*p就是以p的内容为地址的变量*/j=*p;/等价于j=i;printf("i=%d,j=%dn",i,j);经典指针程序_互换两个数:#include<stdio.h>voidhuhuan(int*p,int*q)(intt;/如果要互换p和q的值,贝Ut必须是int*,不能是int,否则会出错/如果要互换*p和*q的值,则t必须定义成int,不能定义成int*,否则语法会出错t=*p
37、;/p是int*,*p是int*p=*q;*q=t;intmain(void)(inta=3;intb=5;huhuan(&a,&b);/huhuan(*p,*q);是错误的,huhuana,b;也是错误的printf("a=%d,b=%dn",a,b);return0;附注:*的含义乘法定义指针变量int*p;/定义了一个名字叫p的变量,int*表示只能存放int变量的地址指针运算符该运算符放在已经定义好的指针变量的前面如果p是一个已经定义好的指针变量2. 贝U*p表示以p的内容为地址的变量如何通过被调函数修改主调函数普通变量的值实参必须为该普通变量的地址
38、形参必须为指针变量在被调函数中通过*形参名=的方式就可以修改主调函数相关变量的值指针和数组指针和一维数组一维数组名一维数组名是个指针常量它存放的是一维数组第一个元素的地址下标和指针如果p是个指针变量,则pi永远等价于*p(p+i)确定一个一维数组需要几个参数【如果一个函数要处理一个一维数组,则需要接收该数组的哪些信息】需要两个参数:数组第一个元素的地址数组的长度指针变量的运算指针变量不能相加不能相乘也不能相除如果两个指针变量指向的是同一块连续空间中的不同存储单元,则这两个指针变量才可以相减。一个指针变量到底占几个字节【非重点】预备知识:sizeof(数据类型)功能:返回值就是该数据类型所占的字
39、节例子:sizeof(int)=4sizeof(char)=1sizet(double)=8sizeof(变量名)功能:返回值是该变量所占的字节数假设p指向char类型变量1个字节假设q指向int类型变量4个字节假设r指向double类型变量8个字节pqr本身所占的字节数是否一样?答案:pqr本身所占字节数是一样的总结:一个指针变量,无论它指向的变量占几个字节该指针变量本身只占四个字节一个变量的地址是用该变量首字节的地址来表小指针和二维数组指针和函数指针和结构体多级指针专题:动态内存分配【重点难点】传统数组的缺点:数组长度必须事现指定,且只能是常整数,不能是变量例子:Inta5;/OKIntl
40、en=5;intalen;/error传统形式定义的数组,该数组的内存程序员无法手动释放数组一旦定义,系统就为该数组分配的存储空间就会一直存在,除非数组所在的函数运行结束或者说:在一个函数运行期间,系统为该函数中数组所分配的空间会一直存在,直到该函数运行完毕时,数组的空间才会被系统释放数组的长度不能在函数运行的过程中动态的扩充或缩数组的长度一旦定义,其长度就不能再更改A函数定义的数组,在A函数运行期间可以被其它函数使用,但A函数运行完毕之后,A函数中的数组将无法再被其他函数使用传统方式定义的数组不能跨函数使用为什么需要动态内存分配内存动态数组很好的解决了传统数组的这4个缺陷传统数组也叫静态数组
41、动态内存分配举例_动态数组的构造静态内存和动态内存的比较静态内存是有系统自动分配,由系统自动释放静态内存是在栈中分配的动态内存是由程序员手动分配,手动释放动态内存是在堆中分配的跨函数使用内存的问题结构体为什么需要结构体为了表示一些复杂的事物,而普通的基本类型无法满足实际要求。什么叫结构体把一些基本类型数据组合在一起形成的一个新的复合数据类型,这个叫做结构体。如何定义结构体3种方式,推荐使用第一种:第一种方式structStudent(intage;floatscore;charsex;;第二种方式structStudent2(intage;floatscore;charsex;st2;第三种方
42、式struct(intage;floatscore;charsex;st3;怎么使用结构体变量赋值和初始化定义的同时可以整体赋初值如果定义完之后,则只能单个的赋初值如何取出结构体变量中的每一个成员【重点】1.指针变量名一成员名第二种方式更常用指针变量名一成员名在电脑内部会被转化成*指针变量名.成员名的方式来执行所以说这两种方式是等价的例子:structStudent(intage;floatscore;charsex;intmain(void)(structStudentst=80,66.6,'F'/初始化定义的同时赋初值structStudent*pst=&st;/&
43、amp;st不能改成stpst->age=88;/第二种方式st.age=10;/第一种方式return0;>在电脑内部会被转换成*pst.age,没有什么为什么,这就是一>的含义,这也是一种硬性规2.所以pst>age等价于st.age,是因为pst>age是被转化成了*pst.age来执行>age的含义:pst所指向的那个结构体变量中的age这个成员结构体变量和结构体变量指针作为函数参数传递的问题推荐使用结构体指针变量作为函数参数来传递结构体变量的运算结构体变量不能相加,不能相减,也不能互相乘除但结构体变量可以相互赋值例子:structStudentintage;charsex;charname100;/分号不能省structStudentst1,st2;st1+st2st1*st2st1/st2都是错误的st1=st2或者st2=st1都是正确的举例动态构造存放学生信息的结构体数组动态构造一个数组,存放学生的信息然后按分数排序输出链表:枚举什么是枚举把一个事物所有可能的取值一一列举出来怎样使用枚举枚举的优缺点代码更安全书写麻烦位运算符:&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 小学英语课堂形成性评价与教师教学评价素养提升的互动关系探讨论文
- 中国医药级赖氨酸行业市场前景预测及投资价值评估分析报告
- 节约型定额管理制度
- 茶餐厅采购管理制度
- 青少年心理与家庭教育咨询工作介绍 与案例咨询探讨
- 自动化专业顶岗实习总结
- 自动控制原理典型习题(含答案)
- 财务会计综合卷
- 幼儿园《包装袋上的秘密》课件
- 2025年android组件化面试字节大牛耗时八个月又一力作大牛最佳总结-android 组件化面试
- 上海浦东新区公办学校储备教师教辅招聘笔试真题2024
- 2025年中国水性马克笔行业市场前景预测及投资价值评估分析报告
- 电动汽车充换电站建设资料标准
- JG/T 375-2012金属屋面丙烯酸高弹防水涂料
- 南邮综评面试题目及答案
- 施工现场劳动力调配与材料保障措施
- 学校档口租赁合同提点模式协议书
- 工商业光伏技术方案
- 2025届四川省宜宾市叙州区英语七下期末质量检测试题含答案
- T/CCOA 62-2023大豆油生产技术规范
- 2025国家开放大学《人文英语1》综合测试形考任务答案
评论
0/150
提交评论