2023年全国计算机二级C语言知识点.pdf

上传人:文*** 文档编号:92971864 上传时间:2023-06-18 格式:PDF 页数:26 大小:3.99MB
返回 下载 相关 举报
2023年全国计算机二级C语言知识点.pdf_第1页
第1页 / 共26页
2023年全国计算机二级C语言知识点.pdf_第2页
第2页 / 共26页
点击查看更多>>
资源描述

《2023年全国计算机二级C语言知识点.pdf》由会员分享,可在线阅读,更多相关《2023年全国计算机二级C语言知识点.pdf(26页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、数组下标的下限是0。土心I 异0L 公共基础知识一、数据结构与算法1、完全二叉树是属于非线性结构,但其最佳存储方式是顺序存储方式2、顺序存储结构中也许根节点不唯一,故也许不是线性结构3、算法的有穷性是指,算法中的操作环节为有限个,且每个环节都能在有限时间内完毕4、法复杂度涉及算法的时间复杂度和算法的空间复杂度。算法设计必须考虑执行算法所需要的资源,即时间与空间复杂度5、算法的优劣取决于算法复杂度,与程序的环境无关,当算法被编程实现之后,程序的运营受到计算机系统运营环境的限制6、循环队列中,由于指针超过队列地址最大值时会移动到队列最小地址处,所以队头指针可以大于也可以小于队尾指针7、链式存储结构

2、中每个结点都由数据域与指针域两部分组成,增长了存储空间8、循环队列是队列的一种顺序存储结构,用队尾指针rear指向队列中的队尾元素,用排头指针front指向排头元素的前一个位置9、设循环队列为Q(1 :m),其初始状态为f r o n t=r ea r=m0通过一系列入队与退队运算后,fro n t=X,r e ar=Y。现要在该循环队列中寻找最大值的元素,最坏情况下需要比较的次数为(1)若X Y,则次数为m(Y-X)-l(2)若X V Y,则次数为丫一 XT1 0、循环队列中的元素个数与队头指针和队尾指针的变化而变化1 1、队列的修改是依先进先出的原则进行的1 2、设计算法时不仅要考虑对数据

3、对象的运算和操作,还要考虑算法的控制结构1 3、顺序表具有以下两个基本特性:(1 )线性表中所有元素所占的存储空间是连续的;(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。(3)在顺序表中,每个元素占有相同的存储单元1 4、设栈的顺序存储空间为S (0:4 9),栈底指针b o t t o m=X,栈顶指针t o p=Y (指向栈顶元素)。则栈中的元素个数为X-Y+11 5、设栈的顺序存储空间为S (1 :m),初始状态为t o p=m+l (X)o现通过一系列入栈与退栈运算后,t o p =2 0(Y),则当前栈中的元素个数为m+l-2 0=m T 9 (X-Y)1 6、设栈的顺

4、序存储空间为S(l:5 0),初始状态为t o p=0。现通过一系列入栈与退栈运算后,t o p =2 0 (X),则当前栈中的元素个数为2 0 (X)二、程序设计基础1、结构化程序设计的思想涉及:自顶向下、逐步求精、模块化、限制使用g o t o 语句2、结构化程序涉及的基本控制结构只有三种,即顺序结构、选择结构与循环结构3、在软件设计中使用的工具P A D 图,不使用的工具数据流图(D F D图)4、对象有如下一些基本特点:标记唯一性、分类性、多态性、封装性、模块独立性好5、多态性是指同一个操作可以是不同对象的行为6、整数类实例涉及:十进制常量用09表达,不能以0开头;八进制常量 用 07

5、表达,必 须 用 0 开头;十六进制常量用09和A F(a f)表达,必须以Ox或 0 X 开头。7、字符实例的一般形式是用一对单引号括起来的一个字符。此外ASCH码中尚有一些控制字符,C语言中用转义字符的形式来书写这些常,转义字符一反斜杠()开始,后面跟1 个字符或字符序列8、继承是面向对象的方法的一个重要特性,是使用已有的类的定义作为基础建立新类的定义技术。广义的说,继承是指可以直接获得已有的性质和特性,而不必反复定义它们,所以说继承是指类之间共享属性和操作的机制三、软件工程基础1、软件指的是计算机系统中与硬件互相依赖的另一部分,涉及程序、数据和有关的文档2、软件具有以下特点:(1)软件是

6、一种逻辑实体,具有抽象性;(2)软件没有明显的制作过程;(3)软件在使用期间不存在磨损、老化问题;(4)对硬件和环境具有依赖性;(5 )软件复杂性高,成本昂贵;(6)软件开发涉及诸多的社会因素,如知识产权等3、软件生命周期可以分为软件定义、软件开发与软件运营维护三个阶段。重要活动阶段是:可行性研究与计划阶段,需求分析,软件设计,软件实现,软件测试,运营和维护(同9)4、计算机软件按功能分为应用软件、系统软件、支撑软件(或工具软件)o系统软件是管理计算机的资源,提高计算机的使用效率,为用户提供各种服务的软件,如操作系统、数据库管理系统、编译程序、汇编程序和网络软件等5、数据定义语言:负责数据的模

7、式定义与数据的物理存取构建;数据操纵语言:负责数据的操纵,涉及查询及增、删、改等操作;数据控制语言:负责数据完整性、安全性的定义与检查以及并发控制、故障恢复等功能。6、软件工程包含3 个要素:方法、工具和过程7、软件产品从考虑其概念开始,到该软件产品不能使用为止的整个时期都属于软件生命周期8、数据库系统的三级模式是概念模式、外模式和内模式。概念模式是数据库系统中全局数据逻辑结构的描述,是全体用户公共数据视图。外模式也称子模式或用户模式,它是用户的数据视图,给出了每个用户的局部数据描述。内模式又称物理模式,它给出了数据库物理存储结构与物理存取方法9、软件生命周期分为3个时期共8个阶段:软件定义期

8、,涉及问题定义、可行性研究、需求分析;软件开发期,涉及概要设计、具体设计、实现、测试;运营维护期,即运营维护阶段。可行性研究属于软件定义期任务(同3)10、可行性分析阶段:可行性分析报告。需求分析阶段:软件规格说明书,初步的用户手册。软件设计阶段:概要设计说明书,具体设计说明书,测试计划初稿。软件实践阶段:用户手册,操作手册等面向用户的文档和单元测试计划。软件测试阶段:测试分析报告。1 1、概要设计说明书是总体设计阶段产生的文档。集成测试计划是在概要设计阶段编写的文档。需求规格说明书是后续工作如设计、编码等需要的重要参考文档12、需求分析阶段的工作可以分为4个方面:需求获取、需求分析、编写需求

9、规格说明书和需求评审,涉及拟定软件系统的功能1 3、(1)在测试之前制定测试计划,并严格执行,测试用例的选择不可随意,应选择有代表性的,尽也许发现迄今为止尚未发现的错误。(2)测试主线目的是尽也许多地发现并排除软件中隐藏的错误(3)软件测试是保证软件质量、可靠性的关键环节。14、在需求分析阶段可以使用的工具有数据流图D FD 图,数据字典DD,鉴定树与鉴定表15、数据流图中带箭头的线段表达的是数据流1 6、数据字典(D D)所定义的对象都包含于数据流图(D F D 图)1 7、软件需求规格说明书有以下几个方面的作用。便于用户、开发人员进行理解和交流;反映出用户问题的结构,可以作为软件开发工作的

10、基础和依据;作为确认测试和验收的依据1 8、软件设计中模块划分应遵循的准则是高内聚低偶合、模块大小规模适当、模块的依赖关系适当1 9、从技术观点上看,软件设计涉及软件结构设计、数据设计、接口设计、过程设计。2 0、减少耦合性提高内聚性有助于提高模块的独立性(高内聚低耦合)21、扇入指的是调用一个给定模块的模块个数2 2、扇出指的是由一个模块直接调用的其他模块数2 3、结构化程序的三种基本控制结构:顺序、选择和循环(反复)2 4、在数据流图中,用标有名字的箭头表达数据流。在程序流程图中,用标有名字的箭头表达控制流。2 5、软件测试的目的是为了发现错误而执行程序的过程。程序调试的基本环节有:错误定

11、位、修改设计和代码,以排除错误、进行回归测试,防止引进新的错误。程序调试通常称为D e b u g,即排错。软件测试的基本准则有:所有测试都应追溯到需求、严格执行测试计划,排除测试的随意性、充足注意测试中的群集现象、程序员应避免检查自己的程序、穷举测试不也许、妥善保存测试计划等文献。2 6、白盒测试又称为结构测试或逻辑驱动测试,对程序所有的逻辑途径进行测试27、黑盒测试只是根据程序的功能说明来设计测试用例。在使用黑盒测试法时,手头只需要有程序功能说明就可以了。黑盒测试法:等价类划分法、边界值分析法和错误推测法四、数据库设计基础1、数据库管理系统是数据库的机构,是一种在操作系统之上的系统软件。2

12、、数据管理技术的发展经历了 3个阶段:人工管理阶段、文献系统阶段和数据库系统阶段。特点人工管理阶段文献系统阶段数据库系统阶段管理者人文献系统数据库管理系统面向对象某个应用程序某个应用程序现实世界共享限度无共享,冗余度大共享性差,冗余度大共享性大,冗余度小独立性不独立,完全依赖于程序独立性差具有高度的物理独立性和一定的逻辑独立性结构化无结构记录内有结构,整体无结构整体结构化,用数据模型描述控制能力由应用程序控制由应用程序控制由DBMS提供数据安全性、完整性、并发控制和恢复3、数据库应用系统中的核心问题是数据库的设计。4、数据库中反映用户对数据规定的模式为外模式5、数据模型通常由数据结构、数据操作

13、及数据约束3部分组成6、数据模型按照不同的应用层次分为3 种类型:概念数据模型、逻辑数据模型、物理数据模型7、数据模型成熟并大量使用的数据模型有层次模型、网状模型、关系模型和面向对象模型等8、关系模型实体间的联系采用二维表来表达,简称表:网状结构为网状模型实体间的联系;树状结构为层次模型实体间的联系;属性刻画了实体。9、在 ER 图中实体集用矩形,属性用椭圆,联系用菱形1 0、二维表中的一行称为元组。候 选 键(码)是二维表中能唯一标记元组的最小属性集。若一个二维表有多个候选码,则选定其中一个作为主 键(码)供用户使用。表M中的某属性集是表N的候选键或者主键,则称该属性集为表M 的外键(码)。

14、1 1、1 9 6 6 年B oeh m 和J a c op i n i 证明了程序设计语言仅仅使用顺序、选择和反复(循环)三种基本控制结构就足以表达出各种其他形式结构的程序设计方法1 2、关系模型中可以有3 类完整性约束:实体完整性约束、参照完整性约束和用户定义的完整性约束。实体完整性约束是指,若属性M是关系的主键,则属性M 中的属性值不能为空值。参照完整性约束是指,若属性(或属性组)A 是关系M 的外键,它与关系M 的主码相相应,则对于关系M中的每个元组在A上的值必须为:要么取空值;要么等于关系M 中某个元组的主码值。13、用于查询的3 个操作无法用传统的集合运算表达,引入的运算为投影运算

15、、选择运算、笛卡尔积。常用的扩充运算有交、除、连接及自然连接等。并:RS是将S中的记录追加到R 后面。交:RS结果是既属于R又属于S的记录组成的集合。上述两种操作中,关系R与S规定有相同的结构,故A、D选项错误。自然连接:去掉反复属性的等值连接。自然连接规定两个关系中进行,比较的是相同的属性,并且进行等值连接。除运算可以近似地看作笛卡尔积的逆运算。当$*丁=区时,则必有R+S=T,T 称为R除以S的商。设关系R有属性此,M 2,,M”,关系S有 属 性+Mn-s+2,M,此时有:1+5=皿 2,3,乂-(区)Ml,M2,Mn-s(Ml,M2,Mn-S(R)XS)o 由 S 中有属性A和Al,T

16、 中属性为B和B l,在R元组中找到相应于S中两个元组的T中元组为f 3与 n 20 R中最后一个元组与S中无相应关系,所以在T中也不会出现。投影,从关系模式中指定若干个属性组成新的关系。二级C语言一、c语言概述1、结构化程序设计把一个复杂问题的求解过程分阶段进行,需要保证自顶向下、逐步细化、模块化设计、结构化编码2、函数体必须由 开始。一个源程序文献可以涉及预解决命令、全局声明、函数定义,程序总是从main函数开始执行的3、算法不一定要包含所有三种基本结构,也可以只包含一种或两种4、算法的复杂程序不是由操作环节多少决定的,而是准时间复杂度与空间复杂度来衡量5、C编译程序把文献后缀为.c 的源

17、程序文献编译成文献后缀为.obj的二进制文献,链接将一个或多个目的文献与程序用到的库文献连接起来,形成一个可以在操作系统直接运营的执行程序.exe6、一个算法应当具有以下五个重要的特性:有穷性,拟定性,输入,输出以及可行性7、只有同时包含三种基本结构时,程序才是结构化程序。一个结构化程序可以包含顺序、分支、循环结构中的一种或多种8、stdio.h文献中包含标准输入输出函数的函数说明,预解决指令t t i n c l u d e 是使程序可以去该文献中找到p r i n t f,s c a n f等函数以便使用9、计算机能直接执行的程序是二进制的可执行程序,扩展名为.exe1 0、算法的特性:有

18、穷性。一个算法(对任何合法的输入)在执行有穷步后可以结束,并且在有限的时间内完毕。拟定性。算法中的每一步都有确切的含义。可行性。算法中的操作可以用已经实现的基本运算执行有限次来实现。输入:一个算法有零个或者多个输入,零个输入就是算法自身拟定了初始条件。输出:一个算法有一个或者多个输出,以反映出数据加工的结果1 1、算法的描述有伪代码、流程图、N-S 结构图等。E R是实体联系模型1 2、C 语言中的非执行语句不会被编译,不会生成二进制的机器指令。C程序通过编译、连接环节之后才干形成一个真正可执行的二进制机器指令文献。用C语言编写的程序称为,它以ASCI I代码形式存放在一个文本文献中。C 语言

19、源程序经编译后生成后缀为.o b j 的目的程序。1 3、C语言的数值常量中不能夹带空格。在C 语言中运算符两侧的运算数据类型可以不一致,且结果与精度较高的保持一致,1 4、C 语言程序是由函数组成的。可以单独进行编译。每个C 程序中必须包含一个m a i n 函数,但不一定是每个C程序文献中必须有,用户单独编写的某个函数也可以存储为一个C 程序文献1 5、一个普通的C 函数可以单独作为一个C的程序文献存在被包含到其他程序中1 6、在复合语句中,不仅可以有执行语句,还可以有定义语句,定义语句应当出现在执行语句的前面1 7、C 语言中的某些语句可以不用分号,例如i f 语句1 8、关键字不可用做

20、用户标记符1 9、C 语言的标记符分为3类:关键字、预定义标记符和用户标记符。常量不属于标记符2 0、一条C语句相应转换成一条机器指令二、运算符与表达式1、s izeof是C 语言中的一个操作符(o p er a t o r)。其作用就是返回一个对象或者类型所占的内存字节数2、条件表达式:x =表达式1?表达式2:表达式3的含义是:先求解表达式1,若为非0 (真),则求解表达式2,将表达式2 的值赋给X。若表达式1 的值为0 (假),则求解表达式3,将表达式3 的值赋给x3、C 语言中没有V 运算符 a%=b 表达a=a%(b)c 语言中”八”的意思是按位异或4、c 语言中八”的意思是按位异或

21、,运算符号按位或 I ,把两个数化为二进制,异为1,同为0,如 1 0 的二进制为00001 01 03的二进制为0 0 00001 1 1 0 八 3=99的二进制为0 0 001 0 01按位与运算,同为1,异为05、在VC 6.0平台中,整型i nt 占有Z个字节,d o u b 1 e 型数据占有 8 个字节。6、算术运算符+的优先级高于-=7、十进制-二进制:十进制除以2,记录余数直到除尽到0,其二进制为这些余数倒着排列。1 0/2=5 余0,5/2=2余1,2/2=1 余0,1/2=0余1,则1 0的二进制为1 0二,由于二进制有8 个 字 节,则 1 0 的二进制为00001 0

22、1 0 o8、二进制-十进制:例:00001 0 0 1 1*2X 4-1)+0*21(3-1)+0*2八(2-1 )+1*2-(1-1)=90 00 0 1 1 1 1 1*2X 4-1)+1*2*(3-1)+1*2 乂 2-1)+1 *2-(1 -1 )=1 59、e xp l&exp 2,规则为:对e x pl求值,若为0,则表达式为0,且不计算e x p2;若e x pl非0,则求e x p2值,作为表达式值1 0、右移运算符,按位右移运算规则是将一个操作数先转换成二进制数,然后将二进制数各位右移若干位,移出的低位舍弃;并在高位补位,若为无符号数,右移时左边高位移入0。例:a =8=0

23、1 000,执行a 2后,a 0 0 01 0 21 1、在C 语言中,乘除法优先级要高于加减法,另一方面,除法运算符7 两边参与运算对象都是整数,运算结果要取整1 2、逗号表达式的值为其中最后一个表达式的值1 3、i+,先使用后自增 自增和自减运算符的两种用法:前置运算,运算符放在变量之前,规则是先使变量的值增(或减)1 ,然后以变化后表达式的值参与其他运算:后置运算,运算符放在变量之后,规则是变量先参与其他运算,然后再使变量的值增(或减)1例:s u m =p a d =5;pA d =s u m+,p Ad+,+p A d ;得:当依仃)=0 时,结束循环,返回字符 0 的 八 5门1

24、码 051 1 1 1 1=5邛2(1=5;pAd=5,s u m=6,p Ad=6,p A d=71 4、计算5/2,结果取整数值2。运算符的两个操作值必须为整型数据1 5、在C 语言中,逻辑真值相应非0。,分支结构的流程走向是根据表达式的值,并不仅仅是算数表达式的值1 6、r a nd ()产生随机整数三、基本语句1、复合语句可以包含多条语句,在其中可以定义局部变量2、花括号对 不仅用来表达函数的开头和结尾,也可以用于表达复合语句3、C语言中的语句必须以分号;结束,所以空语句表达为;,不是空行4、定义语句应当出现在执行语句的前面,在pr i n t f和s c a n f函数中都可以指定数

25、据的宽度,s c a n f ()的格式控制串可以使用其他非空白字符,如逗号,但在输入时必须输入这些字符,以保证匹配,。复合语句可以由任意多条语句构成,可以使一条也可以没有5、当(*s t r)=0 时,结束循环,返回字符 0 的ASCH码06、wh i le循环语句一般形式为:wh i l e (表达式)循环体,执行过程为,一方面判断表达式,成 立(非0)则执行循环体,不成立(0)则退出循环7、g e t s函数,g e t c h a r是用于从终端读入字符。f p u t s函数用于把字符串输出到文献。f wr i t e函数用于以二进制形式输出数据到文献8、s c a n f ()语句

26、中用空格 间隔不同的字符串。g e t c h a r ()函数从终端读入一个字符作为函数值,把读入的字符赋给变量c h。在输入时,空格、回车符都将作为字符读入,并且只有在用户敲入回车键时,读入才开始执行。g e t s ()函数的调用形式为:g e t s(str_ a d r),其中st r _adr是存放输入字符串的起始地址,可以是字符数组名、字符数组元素的地址或字符指针变量。gets函数用来从终端键盘读入字符串(涉及空格符),直到读入一个换行符为止。getc()函数的调用形式为:ch=g e tc(p f)其中p f是文献指针,函数的功能是从pf指定的文献中读入一个字符,并把它作为函数

27、值返回9、scan f函数中的格式控制字符串是为了输入数据用的,无论其中有什么字符,也不会输出到屏幕上。scanf()的格式控制串可以使用其他非空白字符,如逗号,但在输入时必须输入这些字符,以保证匹配就可以。P rin t f函数可以输出常量也可以输出变量,P r i nf函数可以用 来输出百分号%10、数组第一个数为0。由p r intf输出的数据都隐含右对齐。Printf输出数据所占的宽度由系统决定1 1、条件运算符组成条件表达式的一般形式为:表达式1?表达式2:表达式3其求值规则为:假如表达式1的值为真,则以表达式2的值作为条件表达式的值,否则以表达式2的值作为整个条件表达式的值四、选择

28、结构1、在C语言中,逻辑真值相应非0。2、逻辑 非(即运算符!)的运算级别是最高的;算术运算符优先级较高,关系和逻辑运算符优先级较低。3、f o r语句的一般形式为:。1 (表达式1;表达式2;表达式3 )语句其循环中的表达式1 (循环变量赋初值)、表达式2 (循环条件)和表达式3(循环变量增量)都是选择项,即可以缺省,但 ;不能缺省。该题目中省略了表达式1 (循环变量赋初值)和 表达式3(循环变量增量)4、&只有运算对象均非零结果才为真。逻辑与只有在&符号两边操作均为真时,逻辑与为真。”只要有一个对象非零结果就是真。逻辑或当且只当 I 1 符号两边操作至少有一个为真时,逻辑或结果为真5、a!

29、=b 表达a不等于b 时,运算结果为1 ,或者为06、逻辑与运算符遵循 短路求值 策略,即只有在仅靠左操作数的值无法拟定该逻辑表达式的结果时,才会求解右操作数例:若有定义:int a =O,b =0,c=0,d=0 ;,有C 语言表达式(a+&b+)?c+:d+,以下关于其执行顺序的叙述对的是先执行a+,表达式a+的值为0,由此即可拟定(a+&b+)的值为0,因此执行d+7、i f 语句中表达式为1直接执行。为0执行e I s e五、循环结构1、条件表达式的执行次数总是比循环体的执行次数多一次2、设有以下代码d o (w h i l e (条件表达式1)循环体A;w h i l e (条件表达

30、式2);w h i l e (条件表达式1)(d o w h i l e (条件表达式2);)假设表达式1 与表达式2成立次数为n l 与n 2。若n l n 2,则循环体A执行次数为n 2+l,B 执行次数n 2+l;若n l n 2,则循环体A 执行次数为n l,B 执行次数n l3、w h i l e 循环语句一般形式为:w h i l e(表达式)循环体,执行过程为:一方面判断表达式,成 立(非0)则执行循环体,不 成 立(0)则退出循环。do w h i l e循环语句一般形式为:d。循环体 w hi l e(表达式),执行过程为:一方面执行循环体,之后判断表达式,成立(非0)则再一

31、次执行循环体,不 成 立(0)则退出循环。4、在条件相同的情况下,do w h i 1 e 循环比w h i l e d o 多执行一次函数体 两种循环都是在表达式为0时结束循环。do-w h i l e 循环由表达式真假判断是否退出循环,也可以用b r e ak 语句退出循环5、,w h i 1 e 语句的语义是:计算表达式的值,当值为真(非0)时,执行循环体语句.i n t k=0 ;w h i l e (k=l )k+;w h i l e(k=l)=w h i l e (1),是死循环,执行无限次。6、只要适本地修改代码,就可以将do-w h i l e 与w h i 1 e 互相转换。

32、fo r 语句使用最为灵活,它完全可以取代w h i le语句;7、s k -0 为是s 口数组的k 所相应的字符串长度。8、在C 语言中档于号用=表达,一 个 =表达赋值六、数组1、*与&放在一起作用抵消,*(pt+i)表达引用指针pt所指元素后的第i个元素2、#inclu d e main()in t c=10,20,30,4 0,5 0,60,*p,*s;p=c;s=&c 5;p rintf(%dn,s-p);)语句P=c;指将c0元素的地址赋给指针变量p;语句s=&c5;指将c 元素的地址赋给指针变量S3、#inclu d e mai n()in t a5=2,4,6,8,10),*p

33、,*k;p=a;k=&p:prin t f(%d,*(p+);p r in t f(%d n,*k);一方面通过P=a使p指向数组的第1个元素,所以输出2;在输出2以后,由于p+,即p就指向数组的第2个元素,*1就是取出p所指向元素的值,而p指向的是数组的第2个元素,即输出44、通过一条语句可以定义多个数组;数组说明符的一对方括号中可以是整型常量,可以是整型常量表达式;在引用数组元素时,下标表达式必须是整型的。数组下标的下限是0。5、chara 2=A,B );不合法,应为 c ha r a 2=A,B;;用字符串方式赋值比用字符逐个赋值要多占1个字节6、数组下标的下限是0。7、数组名后面括号

34、的值必须是整形常量,不可以是变量8、s ta tic内部静态变量是始终存在的,当函数被调用退出后,内部静态变量会保存数据,再次调用该函数时,以前调用时的数值仍然保存着9、vo i d fu n(i n t*a,int n)/*fun函数的功能是将a所指数组元素从大到小排序*/fun(c+4,6);即指排序从第5个元素开始进行从大到小排序。10、数组说明的一般形式为:类型说明符数组名 常量表达式11,指针的赋值一方面基类型必须一致,s二维数组名,是二维数组的首地址,其基类型是一个具有10个元素的字符数组。P是一个字符指针变量,其基类型是一个字符,k是一个行指针,其基类型是具有3个元素的字符型数组

35、。七、函数1、C程序中主函数不能被其他函数调用。main函数可以放在程序开始,也可以放在中间,也可以放在最后,位置不固定,但程序执行时必须从ma i n函数开始。在C程序的函数中不能定义另一个函数,可以声明或调用另一个函数。每个C程序中必须包含一个m ain函数,但不一定是每个C程序文献中必须有,用户单独编写的某个函数也可以存储为一个C程序文献2、数学库中定义了函数的名称、参数个数与类型、返回值类型与具体的函数体,编译预解决时,预解决程序将查找指定的被包含文献,并将其复制到#in c 1 ude命令出现的位置上,不引用math,h文献,文献编译时,编译器无法辨认没有被定义的sin函数。若要使用

36、C数学库中的sin函数,需要在源程序的头部加上#i nclude 通过引用m a t h,h文献,说明s i n函数的参数个数和类型,以及函数返回值类型3、函数调用时,函数名称是需要区分大小写的;函数名不允许以数字开头;在函数中允许有多个r e t u r n语句,但每次调用只能有一个r e t u r n语句被执行4、用户自己定义的函数能调用库函数也可以调用自定义函数;对于不同函数的形式参数可以使用相同名称的标记符;关于函数的定义不可以嵌套,但函数的调用可以嵌套。5、不能将一个整数直接赋给指针变量作为地址。函数的返回值可以是地址,即指针。函数调用中形参值的变化不会传递给实参。6、C语言规定,

37、实参变量对形参变量的数据传递是“值传递”,即单向传递,只由实参传给形参,而不能由形参传回来给实参。在内存中,实参单元与形参单元是不同的单元。7、C程序必须由一个或一个以上的函数组成;函数调用可以作为一个独立的语句存在;若函数有返回值,必须通过r e t u r n语句返回8、语句f(&a 2,5,0)的作用是对从a 2开始的5个元素进行从大到小排序。9、v o i d f (i n t *s)*s =k;m a i n ()i n t m=3,*p=&m;f(p);p r i n t f (*%d ,%d*,m,*p );m=3,p指向m,调用函数f ,将实参p中m的地址传递给形参s,s指向r

38、 n,贝i j k赋值给叫m=5,p仍然指向m,故输出5,51 0、函数调用中发生的数据传送是单向的。即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化A.指针1、在计算机内存中,用一个字节表达一个内存单元并为每一个存储单元编号,这个编号就是存储单元的 地址。一个变量的地址称为该变量的 指针”。专门用来存放变量地址的变量,称为指针变量”。常量存储在编译文献中,不能取地址。一个指针变量的地址只能赋给指向这种类型的指针变量,与其自身类型不同,不能赋值,未赋初值的指针变量自动赋任意地址值2、所有地址值所占字节都是同样的,故指针变

39、量所占内存大小同样;不能随意把一个地址存放到任何一个指针变量中去,只能把具有相同类型的变量的地址,存放到这个指针变量中,结构体变量与某个成员类型不同,不能用同样的指针指向它们3、#incl u de vo id f(i n t*p,in t*q);main()(int m=l,n=2,*r=&m;f(r,&n);pr i nt f(%d,%d”,m,n);)v oi d f(int*pjnt*q)(P=P+1 ;*q =*q+1;)在f(int*p,int*q)函数中,执行p=p+l是将p所相应的地址加1,而*q=*q+l是将q所指向的n的地址所相应的值加1 ,所以m的得知所相应的值没有变,而

40、n的值则为3了。4、假如p是指针变量,则*P表达变量p所指向的地址的值;假如P是指针变量,则&P表达变量p的地址;假如P是指针变量,*P+1表达将p所指的值加上L而*(P+1)表达的是先将指针右移一位再取所指向变量的值。5、虽然不同基类型的指针变量占用字节数是相同的,但是不能混用。6、f Io a t a10,x:表达式a+l不是非法的;语 句a=&x;是非法的7、a=(*p tr)+表达把指针p tr相应地址单元里的值赋给a,再将p t r相应地址单元里的值加18、定义指针P后,必须指针p进行初始化就进行赋值9、i nt x=2,*p=&x;f l o a t y=3.0:c h a r z

41、=c由于X是一个整形变量,将X地址赋值给p指针后,对P进行加一运算,p指针的值相称于加4 (整型变量的地址占4个字节),此时p指向了未知的内存地址,对未知内存地址进行操作具有安全隐患1 0、把一个指针变量的值赋给另一个指针变量,但一定要保证这两个指针变量的基类型是相同的;只要两个指针变量基类型相同,可以指向同一个对象1k函数的返回值可以是地址,即指针。函数调用中形参值的变化不会传递给实参。不能将一个整数直接赋给指针变量作为地址;函数可以返回地址值;改变函数形参的值,不会改变相应实参的值:当在程序的开头包含头文献s t d i。.h时,可以给指针变量赋N U L L1 2、指针是用来存放地址的变

42、量,用(类型名*指针变量名)的形式定义。赋值时应将某个变量地址即&x赋给指针变量)。1 3,p=N U L L;和p=0;或p =0 ;等价;语句p=N U L L;执行后,指针p并不是指向地址为。的存储单元,而是具有一个拟定的值-空。1 4、指针变量的赋值只能赋予地址,决不能赋予任何其它数据,否则将引起错误;p=N U L L;和p=0;是等价的;指向同一数组的两指针变量进行关系运算可表达它们所值数组元素之间的关系。假如企图通过一个空指针来访问一个存储单元,将会得到一个犯错信息1 5、不可以取一个常数或表达式的地址赋值给同类型的指针变量;通过强制类型转换可以将一种类型的指针变量赋值给另一种类

43、型的指针变量1 6、若有定义语句:i nta 2 3 J,*p 3 ;则以下语句中对的的是A)p=a;B)p 0 =a;C)p 0 =&a l 2 ;D)p 1 =&a;参考答案:C【解析】A选项错误,由于p是指向一个指针数组,作为数组名,不能指向别的地方。B选项错误,由于p 0 是一个i n t指针,也就是i n t*;而a是一个指向指针的指针i n t*。C选项对的,由于p 0 是一个i n t*,a 1 2 是i n t,&a l 2 是i n t *,类型吻合。D选项错误,由于a作为数组名,不能取地址。即使能取,p 1 是i n t*,&a是i n t*,类型不对。因此C选项对的。1

44、7、i n t *p;s c an f(%d,p );没有对指针进行初始化,无效指针1 8、不允许把一个数赋予指针变量,被赋值的指针变量前不能再加*说明符19、若有定义语句:in t a10=0,I,2,3,4,5,6,7,8,9,*p=a;,以下选项中错误引用a数组元素的是(其中 OWi t y p e d e f s t r u e t D a t e i n t y e a r ;i n t m o n t h ;i n t d a y;D A T E ;则以下叙述中错误的是A)D A T E 是用户定义的结构体变量B)s t r u c t D a t e 是用户定义的结构体类型C)D

45、 A T E 是用户说明的新结构体类型名D)s t r u c t 是结构体类型的关键字C语言允许用typedef说明一种新类型名,其一般形式如下:ty p e d e f类型名 新类型名;,题目中定义了新类型D a te,这种类型变量包含3个成员,DATE是这种新类型的名字。DATE是用户说明的新结构体类型名,不是结构体变量,C选项叙述对的,A选项叙述错误,选择A选项。s tru c t Date是用户定义的结构体类型,B选项叙述对的。st r uct是结构体类型的关键字,D选项叙述对的。9、C语言中没有逻辑类型;若要保存带有多位小数的数据,可以用单精度类型也可以用双精度类型.解决包含不同类

46、型的相关数据可以定义为结构体类型。整数类型可以无误差的表达自然数。10、一个结构体类型可以由多个称为成员(或域)的成分组成;结构体类型中的成分可以是结构体;定义结构体时编译程序并不会给它分派内存空间;结构体中各个成分的类型可以是不同样的1 1,不能在定义结构体的同时,又用结构体类型名定义变量。十一、文献1、文献是由数据序列组成,可以构成二进制文献或文本文献2、f p =f o p e n(*r e s.t x t ,w );f p u t c (K +i,f p);f c l o s e(f p);执行打开文献re s.tx t、写入文献、再关闭文献的操作,由于fop 011函数使用 0 模式

47、写文献,所以每次打开re s.tx t后,都删除文献中的原有数据,再重新写入新数据。3、文献指针指向的是文献缓冲区,而不是文献自身位置,文献指针是指针类型的变量;f scanfO函数作用是从指定的文献中格式化读数据,读取数据类型由格式控制符决定4、文献指针是程序中用FILE定义的指针变量;在C语言中用一个指针变量指向一个文献,这个指针称为文献指针。通过文献指针就可对它所指的文献进行各种操作。文献指针不是文献位置指针5、文献指针是指针变量,存储的是文献缓存区首地址6、所谓文献指针,事实上是指向一个结构体类型的指针变量,这个结构体中包具有文献的一些信息,如缓冲区的地址,在缓冲区中当前存取的字符的位置,对文献是 读 还是 写,是否犯错,是否己经碰到文献结束标志等信息。7,当对文献的读(写)操作完毕之后,必须将它关闭,否则也许导致数据丢失;打开一个已存在的文献并进行了写操作后,原有文献中的所有数据不一定被覆盖,也可以对源文献进行追加操作等。在一个程序中当对文献进行了写操作后,不用先关闭该文献然后再打开,才干读到第1个数据,可以用fs e ek()函数进行重新定位即可。C语言中的文献可以进行随机读写。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁