全国计算机二级C语言(经典复习资料) 下载本文

【考点 3】字符型数据可以和整型数据相互转换

如:’0’-0=48 ‘A’+32=’a’ char a=65;printf(“%d%c”,a,a);结果为 65A 【考点 4】位运算符

C 语言提供 6 种位运算符:按位求反~,按位左移<<,按位右移>>,按位与&,按位异 或|,按位或^。一般情况下需要先转化进制。异或运算的规则:0 异或 1 得到 1,0 异或 0 得 到 0,1 异或 1 得到 0。可记为“相同为 0,不同为 1”。 【考点 5】putchar 与 getchar 函数

可用于输出或输入单个字符,这两个函数是 stdio.h 文件中的库函数,它们是 printf 与 scanf 函数的简化。

第六章 函数

【考点 1】函数的定义

函数是具有一定功能的一个程序块。函数的首部为:函数类型 函数名(类型 1 形参 1, 类型 2 形参 2,??)。在函数定义中不可以再定义函数,即不能嵌套定义函数。函数类型 默认为 int 型。 【考点 2】库函数 调用 C 语言标准库函数时要包含 include 命令,include 命令行以#开头,后面是””或<> 括起来的后缀为”.h”的头文件。以#开头的一行称为编译预处理命令行,编译预处理不是 C 语言语句,不加分号,不占运行时间。 【考点 3】函数的返回值 函数通过 return 语句返回一个值,返回的值类型与函数类型一样。return 语句只执行一 次,执行完或函数体结束后退出函数。 【考点 4】函数的声明

函数要“先定义后调用”,或“先声明再调用后定义”。函数的声明一定要有函数名、函 数返回值类型、函数参数类型,但不一定要有形参的名称。 【考点 5】函数的调用

程序从上往下执行,当碰到函数名后,把值传给调用函数,当程序得到了返回值或调用 函数结束,再顺序往下执行。 【考点 6】函数的参数及值传递

形式参数简称形参,是定义函数时函数名后面括号中的参数。实在参数简称实参,是调 用函数时函数名后面括号中的参数。实参和形参分别占据不同的存储单元。实参向形参单向 传递数值。

“传值”与“传址”的区别:传数值的话,形参的变化不会改变实参的变化。传地址的 话,形参的变化就有可能改变实参所对应的量。 【考点 7】函数的递归调用

函数直接或间接地调用自己称为函数的递归调用。递归调用必须有一个明确的结束递归 的条件。在做递归题时可把递归的步骤一步步写下来,不要弄颠倒了。 【考点 8】要求掌握的库函数

sqrt()算术平方根函数,fabs()绝对值函数,pow()幂函数,sin()正弦函数

第七章 指针

【考点 1】指针变量

指针变量是用来存储地址的,而一般变量是存储数值的。指针变量可指向任意一种数据 类型,但不管它指向的数据占用多少字节,一个指针变量占用四个字节。

4

【考点 2】指针变量的定义

格式为:类型名 *指针变量名。二维指针 int **p;可以理解为基类型为(int *)类型。 【考点 3】指针变量的初始化 指针变量在使用前必须要初始化,把一个具体的地址赋给它,否则引用时会有副作用, 如果不指向任何数据就赋“空值”NULL。 【考点 4】指针变量的引用 &是取地址符,*是间接访问运算符,它们是互逆的两个运算符。在指针变量名前加间 接访问运算符就等价它所指向的量。 【考点 5】指针的运算 *p++和(*p)++之间的差别:*p++是地址变化,(*p)++是指针变量所指的数据变化。一个 指针变量加一个整数不是简单的数学相加,而是连续移动若干地址。当两个指针指向同一数 组时,它们可以比较大小进行减法运算。

第八章 数组

【考点 1】数组的定义

数组是一组具有相同类型的数据的集合,这些数据称为数组元素。格式为:类型名 数 组名[常量表达式]。数组的所占字节数为元素个数与基类型所占字节数的乘积。 【考点 2】数组的初始化 第一维长度可以不写,其它维必须写。int a[]={1,2};合法,int a[][3]={2,3,4};合法,int a[2][]={2,3,4};非法。数组初始化元素值默认为 0,没有初始化元素值为随机。如在 int a[5]={0,1,2};中,元素 a[4]值为 0;而在 int a[5];中,元素 a[4]值为一个不确定的随机数。 【考点 3】元素的引用

数组元素的下标从 0 开始,到数组长度减 1 结束。所以 int a[5];中数组最后一个元素是 a[4]。要把数组元素看作一个整体,可以把 a[4]当作一个整型变量。 【考点 4】二维数组 数组 a[2][3]={1,2,3,4,5,6};中含 6 个元素,有 2 行 3 列。第一行为 a[0]行,第 2 行为 a[1] 行,a[0]、a[1]叫行首地址,是地址常量。*(a[0]+1)是第一行第一个元素往后跳一列,即元素 a[0][1]值为 2,*(a[0]+3)是第一行第一个元素往后跳三个,即元素 a[1][0]值为 4。 【考点 5】行指针 是一个指针变量,占四个字节,行指针指向一行连续数据,形式为:int (*p)[2];,p 只 能存放含有两个整型元素的一维数组的首地址。注意(*p)两边的小括号不能省略,否则就成 了指针数组,是若干指针元素的集合。 【考点 6】数组名 数组名是数组的首地址。数组名不能单独引用,不能通过一个数组名代表全部元素。数 组名是地址常量,不能对数组名赋值,所以 a++是错误的。但数组名可以作为地址与一个整 数相加得到一个新地址。 【考点 7】元素形式的转换 助记:“脱衣服法则”a[2]变成*(a+2),a[2][3]变成*(a+2)[3]再可变成*(*(a+2)+3)。

第九章 字符串

【考点 1】字符串常量及表示

字符串常量是由双引号括起来的一串字符,如”ABC”。在存储字符串时,系统会自动 在其尾部加上一个空值’\\0’,空值也要占用一个字节,也就是字符串”ABC”需要占四个 字节。

5

【考点 2】字符数组

C 语言没有字符串变量,只能采用字符数组来存储字符串。数组的大小应该比它将要实 际存放的最长字符串多一个元素,从而存放’\\0’。 【考点 3】字符串赋值 可以用下面的形式进行赋值:char str[]=”Hello!”;或 char *p;p=”Hello!”;,但不能用 下面的形式:char str[10];str=”Hello”;因为 str 是一个地址常量,不能进行赋值操作。 【考点 4】字符串的输入与输出 可以用 scanf 和 printf 函数,如 scanf(”%s”,str);,也可用专门处理字符串的两个函数 gets 和 puts 函数,还可以对字符数组逐个元素进行赋值,但一定要在最后赋一个’\\0’。使 用 gets 函数可以接收空格,使用 puts 函数在最后输出一个换行。 【考点 5】字符串函数 要掌握的四个字符串函数:字符串拷贝函数 strcpy(),求字符串长度函数 strlen(), 字符串链接函数 strcat(),字符串比较函数 strcmp()。使用这些函数需在预处理部分包含 头文件”string.h”。

字符串长度要小于字符数组的长度,例:char str[10]=”Hello”;sizeof(str)的值为 10(数 组长度),strlen(str)的值为 5(字符串长度)。这些函数是考试常用到的函数,大家一定要熟 练应用这几个函数。

第十章 结构体与共用体

【考点 1】结构体类型的说明

结构体是若干个类型数据的集合,结构体类型说明格式如下:struct 类型名 {类型 1 成 员名 1;类型 2 成员名 2;??};,以上整个部分是一个数据类型,与整型的 int 是同样地位。 可用 typedef 把结构体类型替换成一个只有几个字母的简短标识符。 【考点 2】结构体变量的定义

结构体变量是用说明的结构体类型所定义的一个变量,与结构体类型不是一回事。一个 结构体变量所占字节数为其所有成员所占字节数之和。如 struct stu{char name[10];int age;} a,b;则表明定义了两个结构体变量 a,b,每个变量占 14 个字节。a,b 与 int i,j;中的变量 i,j 是同样 地位。 【考点 3】结构体成员的引用

引用成员可用以下 3 种方式:(1)结构体变量名.成员名;(2)指针变量名->成员名:(3) (*指针变量名).成员名。点(.)称为成员运算符,箭头(->)称为结构指向运算符。 【考点 4】链表

链表是由一个个结点构成的,一个结点就是一个结构体变量。每个结点可以分为数据域 与指针域两个部分,数据域用来存放要存储的数据,指针域用来指向下一个结点。链表是考 试中的难点,在 C 语言和公共基础部分都会考到,要领悟掌握。 【考点 5】共用体 共用体的使用格式与结构体相似,共用体定义的关键字为 union,共用体所占字节数是 所有成员中字节数最大的那个。

第十一章 文件

【考点 1】文件类型指针

文件指针是一个指向结构体类型的指针,定义格式为:FILE *指针变量名。在使用文件 时,都需要先定义文件指针。 【考点 2】文本文件与二进制文件

6

文本形式存放的是字符的 ASCII 码,二进制形式存放的是数据的二进制。例如“100” 如果是文本形式就是存储’1’、 ’0’、 ’0’三个字符的 ASCII 码(00110001 00110000

00110000),如果是二进制形式就把 100 转化成二进制(01100100)。

【考点 3】打开文件 文件的打开形式如下:FILE *fp; fp=fopen(“c:\\\\lab.c”,”rb”);。fopen 函数的前面一 部分为文件名,后面一部分为文件的使用方式。打开方式详见教材第 127 页,其中 r 代表读, w 代表写,a 代表添加,b 代表二进制位的。 【考点 4】文件函数 判断文件结束 feof 函数,移动文件指针位置 fseek 函数,获得文件位置 ftell 函数,文件 位置移到开头 rewind 函数,文件字符输入输出 fgetc 函数和 fputc 函数,文件输入输出 fscanf 函数和 fprintf 函数,文件字符串输入输出 fgets 函数和 fputs 函数,读写二进制文件 fread 函 数和 fwrite 函数。

以上函数要求知道格式会用,清楚是用于二进制文件还是文本文件,要把教材文件这章 仔细复习下,不要在考试的时候把这些文件函数搞混了。

第十二章 深入讨论

【考点 1】编译预处理

凡以#开头的这一行,都是编译预处理命令行,编译预处理不加分号,不占运行时间。 宏替换仅是简单的文本替换,如#define f(x) (x)*(x)和#define f(x) x*x 替换 f(2+2)时就 有区别,前者展开为(2+2)*(2+2),后者为 2+2*2+2。 如果源文件 f2.c 中有#include”f1.c”可以理解为把源文件 f1.c 原样包含到 f2.c 中,使 f1.c 和 f2.c 融合到一起成为一个 C 程序编译。所以一个 C 程序必有主函数,但一个 C 源文 件未必有主函数。 【考点 2】标识符作用域

局部变量是在函数内或复合语句内定义的变量,作用域为定义它的函数内。局部变量有 三种类型:自动 auto,寄存器 register 和静态 static。

自动变量随着函数的使用与否创建消失;寄存器变量分配在 cpu 中,没有内存地址;静 态变量占用固定存储单元,在程序执行过程不释放,直到程序运行结束。 全局变量是在函数外定义的变量,作用域从定义它的位置到整个源文件结束为止,生存 期为整个程序运行期间。全局变量都是静态变量。 【考点 3】动态存储分配 malloc(size)用来创建连续 size 个字节存储区,返回值类型为 void *型。malloc 函数常用 于动态创建链表结点,如 int *p; p=(int *)malloc(sizeof(int));。

calloc(n,size)创建 n 个同一类型的存储空间,可以理解为 n 个 malloc。 free(p)释放动态分配的存储单元。

7