C语言复习笔记(2)

第四章 函数

1.自定义函数

自定义函数的基本结构

[数据类型说明] 函数名称 ([参数])

{

执行代码块;

return (表达式);

}

注意:

1、[]包含的内容可以省略,数据类型说明省略,默认是int类型函数;参数省略表示该函数是无参函数,参数不省略表示该函数是有参函数;

2、函数名称遵循标识符命名规范

3、自定义函数尽量放在main函数之前,如果要放在main函数后面的话,需要在main函数之前先声明自定义函数,声明格式为:[数据类型说明] 函数名称([参数]);


2.函数调用

函数调用的==一般形式==为:

函数名([参数]);

注意:

1、对无参函数调用的时候可以将[]包含的省略。

2、[]中可以是常数,变量或其它构造类型数据及表达式,各参数之间用逗号分隔。


3.函数分类

有参与无参

在函数中不需要函数参数的称之为无参函数

在函数中需要函数参数的称之为有参函数

一般形式如下:

无参函数一般形式 有参函数一般形式

​ [数据类型说明] 函数名称 () [数据类型说明] 函数名称 (参数列表)

​ { {

​ 执行代码块; 执行代码块;

​ return 表达式; return 表达式;

​ } }

区别:

有参函数和无参函数的唯一区别在于:函数()中多了一个参数列表。

形参与实参
  1. 函数的参数分为形参实参两种

  2. 形参是在定义函数名和函数体的时候使用的参数,目的是用来接收调用该函数时传入的参数

  3. 实参是在调用时传递该函数的参数

注意:形参和实参有以下特点:
  • 形参只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只有在函数内部有效。函数调用结束返回主调函数后则不能再使用该形参变量。
  • 实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值,以便把这些值传送给形参。因此应预先用赋值等办法使实参获得确定值。
  • 在参数传递时,实参和形参在数量上,类型上,顺序上应严格一致,否则会发生类型不匹配”的错误。

4.函数的返回值

  1. 函数的返回值是指函数被调用之后,执行函数体中的程序段所取得的并返回给主调函数的值。

  2. 函数的值只能通过return语句返回主调函数。

  3. return语句的一般形式为:

    return 表达式 或者为: return (表达式);

    1)函数值的类型和函数定义中函数的类型应保持一致。如果两者不一致,则以函数返回类型为准,自动进行类型转换。

    2)没有返回值的函数,返回类型为void。如果小刚算了一会没有返回结果的话,那么用代码表示就是:

    void noResult()

    {

    }

    注意:void函数中可以有执行代码块,但是不能有返回值,另void函数中如果有return语句,该语句只能起到结束函数运行的功能。

    其格式为:return;


5.递归函数

  1. 递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。
  2. 递归函数必须有结束条件

递归函数特点

  1. 每一级函数调用时都有自己的变量,但是函数代码并不会得到复制,如计算5的阶乘时每递推一次变量都不同;
  2. 每次调用都会有一次返回,如计算5的阶乘时每递推一次都返回进行下一次;
  3. 递归函数中,位于递归调用前的语句和各级被调用函数具有相同的执行顺序;
  4. 递归函数中,位于递归调用后的语句的执行顺序和各个被调用函数的顺序相反;
  5. 递归函数中必须有终止语句。

6.局部变量和全局变量

  1. C语言中的变量,按作用域范围可分为两种,即局部变量和全局变量

  2. 局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内, 离开该函数后再使用这种变量是非法的。在复合语句中也可定义变量,其作用域只在复合语句范围内。

  3. 全局变量也称为外部变量,它是在函数外部定义的变量。它不属于哪一个函数,它属于一个源程序文件。其作用域是整个源程序


7.变量储存类别

C语言根据变量的生存周期来划分,可以分为静态存储方式动态存储方式

C语言中存储类别又分为四类:自动(auto)、静态(static)、寄存器的(register)和外部的(extern)

静态存储方式:是指在程序运行期间分配固定的存储空间的方式。静态存储区中存放了在整个程序执行过程中都存在的变量,如全局变量。

1、static修饰的为静态变量,如果定义在函数内部的,称之为静态局部变量;如果定义在函数外部,称之为静态外部变量

==动态存储方式:==是指在程序运行期间根据需要进行动态的分配存储空间的方式。动态存储区中存放的变量是根据程序运行的需要而建立和释放的,通常包括:函数形式参数;自动变量;函数调用时的现场保护和返回地址等。

1、用关键字auto定义的变量为自动变量,auto可以省略,auto不写则隐含定为“自动存储类别”,属于动态存储方式

==注意:==静态局部变量属于静态存储类别,在静态存储区内分配存储单元,在程序整个运行期间都不释放;静态局部变量在编译时赋初值,即只赋初值一次;如果在定义局部变量时不赋初值的话,则对静态局部变量来说,编译时自动赋初值0(对数值型变量)或空字符(对字符变量)

· 为了提高效率,C语言允许将局部变量得值放在CPU中的寄存器中,这种变量叫“寄存器变量”,用关键字register作声明。

·extern声明的的变量是外部变量,外部变量的意义是某函数可以调用在该函数之后定义的变量。

注意:只有局部自动变量和形式参数可以作为寄存器变量;一个计算机系统中的寄存器数目有限,不能定义任意多个寄存器变量;局部静态变量不能定义为寄存器变量。

1.jpg
2.jpg

第五章 数组

1.数组定义

数组在程序中是一块连续的,大小固定并且里面的数据类型一致的内存空间

如何声明一个数组

数据类型 数组名称[长度];

如何数组初始化,有三种形式的,分别是:

1、 数据类型 数组名称[长度n] = {元素1,元素2…元素n};

2、 数据类型 数组名称[] = {元素1,元素2…元素n};

3、 数据类型 数组名称[长度n]; 数组名称[0] = 元素1; 数组名称[1] = 元素2; 数组名称[n-1] = 元素n;

注意:

1、数组的下标均以0开始

2、数组在初始化的时候,数组内元素的个数不能大于声明的数组长度;

3、如果采用第一种初始化方式,元素个数小于数组的长度时,多余的数组元素初始化为0;

4、在声明数组后没有进行初始化的时候,静态(static)和外部(extern)类型的数组元素初始化元素为0,自动(auto)类型的数组的元素初始化值不确定

2,数组的遍历

那么在程序中,数组就可以采用循环的方式将每个元素遍历出来,而不用人为的每次获取指定某个位置上的元素

例如我们用for循环遍历一个数组

数组遍历时要注意以下几点:

1、最好避免出现数组越界访问,循环变量最好不要超出数组的长度

2、C语言的数组长度一经声明,长度就是固定,无法改变,并且C语言并不提供计算数组长度的方法。

由于C语言是没有检查数组长度改变或者数组越界的这个机制,可能会在编辑器中编译并通过,但是结果就不能肯定了,因此还是不要越界或者改变数组的长度

3.jpg

3.数组作为函数

1、整个数组当作函数参数,即把数组名称传入函数中

2、数组中的元素当作函数参数,即把数组中的参数传入函数中

数组作为函数参数时注意以下事项:

1、数组名作为函数实参传递时,函数定义处作为接收参数的数组类型形参既可以指定长度也可以不指定长度。

2、数组元素作为函数实参传递时,数组元素类型必须与形参数据类型一致

4.字符数组

一般有以下==两种格式==:

1、char 字符串名称[长度] = “字符串值”;

2、char 字符串名称[长度] = {‘字符1’,‘字符2’,…,‘字符n’,‘\0’};

注意:

1、[]中的长度是可以省略不写的;

2、采用第2种方式的时候最后一个元素必须是’\0’,'\0’表示字符串的结束标志;

3、采用第2种方式的时候在数组中不能写中文

在输出字符串的时候要使用:printf(“%s”,字符数组名字); 或者puts(字符数组名字);

5.字符串函数

**1、**strlen() 获取字符串的长度,在字符串长度中是不包括‘\0’而且汉字和字母的长度是不一样的

2、strcmp() 在比较的时候会把字符串先转换成ASCII码再进行比较,返回的结果为0表示s1和s2的ASCII码相等**,返回结果为1表示s1比s2的ASCII码大,返回结果为**-1表示s1比s2的ASCII码小**

**3、**strcpy() 拷贝之后会覆盖原来字符串且不能对字符串常量进行拷贝

**4、**strcat() 在使用时s1与s2指的内存空间不能重叠,且s1要有足够的空间来容纳要复制的字符串

6.多维数组

多维数组的定义格式是:

数据类型 数组名称 [常量表达式1] [常量表达式2]…[常量表达式n];

多维数组的初始化与一维数组的初始化类似也是分两种

**1、**数据类型 数组名称 [常量表达式1] [常量表达式2]…[常量表达式n] = {{值1,…,值n},{值1,…,值n},…,{值1,…,值n}};

**2、**数据类型 数组名称 [常量表达式1] [常量表达式2]…[常量表达式n]; 数组名称 [下标1] [下标2]…[下标n] = 值;

多维数组初始化要注意以下事项:

**1、**采用第一种始化时数组声明必须指定列的维数。因为系统会根据数组中元素的总个数来分配空间,当知道元素总个数以及列的维数后,会直接计算出行的维数

**2、**采用第二种初始化时数组声明必须同时指定行和列的维数。

注意:多维数组的每一维下标均不能越界

感谢您的观看,如果觉得好的话,可以点个小赞吗,谢谢!!!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鱼大虾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值