1.getchar函数
能够获取字符,用循环能一直打印字符,EOF作为结束条件,输入CTRL+z结束文件。
2.函数
函数可以分为两大类(1)库函数
(2)自定义函数
(1)库函数的介绍以及怎么自己了解并且使用库函数
简单来说所谓库函数就是我们在开发的过程中每个程序员都可能用的到,为了支持可移植性和提高程序的效率,所以C语言的基础库中提供了一系列类似的库函数。
学习并了解库函数的使用可以在这个网站学习了解https://cplusplus.com/
简单的总结,C语言常用的库函数都有:
- IO函数
- 字符串操作函数
- 字符操作函数
- 内存操作函数
- 时间/日期函数
- 数学函数
- 其他库函数
在这里可以了解我们常用的库函数,比如printf,scanf,输入输出函数。
接下来,我带大家来演示两个库函数(strcpy,memset)的使用以及怎么阅读文档。
strcpy
在上述网站中输入该库函数,其实可以简单的看出该库函数的作用str+copy,字符串拷贝如果看不出来,文档会告诉你。
在函数的功能使用,可以自己简单翻译来使用。
Copies the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point).
其意思就是拷贝c的字符串从source拷贝到目的地,并且包括空字符
其实arr1打印的5个字符‘a’‘b’‘c’‘d’‘\0’;明白其基本含义就可以简单的使用
memset
其实也可以简单的理解memery+set就是内存设置,不懂还是可以看其解释
memset功能
Sets the first num bytes of the block of memory pointed by ptr to the specified value (interpreted as an unsigned char).
将 ptr 所指向的内存块的前一个字节数设置为指定值
(2)自定义函数
自定义函数和库函数一样,有函数名,返回值类型和函数参数。但是不一样的是这些都是我们自己来设计。
设计一个加法函数
3.函数的参数
函数参数分为形式参数和实际参数
实际参数:真实传给函数的参数,叫实参。实参可以是:常量、变量、表达式、函数等。
无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形
参。
形式参数:形式参数是指在函数声明时函数名后括号中的变量,因为形式参数只有在函数被调用的过程中才实例化(分配内存单元),所以叫形式参数。形式参数当函数调用完成之后就自动销毁了。因此形式参数只在函数中有效。
可以简单理解为:形参实例化之后其实相当于实参的一份临时拷贝.
4.函数的调用
函数调用也分为两种:传值调用和传值调用。
传值调用:函数的形参和实参分别占有不同内存块,对形参的修改不会影响实参。靠返回值。
例如上面这个加法函数只是将a和b的值传给形式参数,而形式参数值的改变不会影响实际参数,只是要返回值的值,最后输出的也是返回值的值
传址调用:传址调用是把函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式。
这种传参方式可以让函数和函数外边的变量建立起真正的联系,也就是函数内部可以直接操
作函数外部的变量。通过传地址来,改变地址来改变数。
比如写一个函数交换两个数的值。
5.函数函数的嵌套调用和链式访问
函数和函数之间可以根据实际的需求进行组合的,也就是互相调用的。
嵌套调用:函数可以嵌套调用,但是不能嵌套定义。
#include <stdio.h>
void new_line()
{
printf("hehe\n");
}
void three_line()
{
int i = 0;
for (i = 0; i < 3; i++)
{
new_line();
}
}
int main()
{
three_line();
return 0;
}
链式访问:把一个函数的返回值作为另外一个函数的参数。
#include <stdio.h>
int main()
{
printf("%d", printf("%d", printf("%d", 43)));
return 0;
}
printf的返回值打印字符的个数,用printf的返回值来作为printf的参数。
6.函数的声明和定义
函数的声明:
- 就是告述编译器函数 的返回类型,以及参数类型,和函数叫什么。
- 必须满足先声明后使用。
- 并且函数的声明一般放在头文件。
函数的定义:函数的定义是指函数的具体实现,交待函数的功能实现。
7.函数的递归
递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接 调用自身的 一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解, 递归策略 只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。 递归的主要思考方式在于:把大事化小。
递归的两个必要条件
- 存在限制条件,当满足这个限制条件的时候,递归便不再继续。
- 每次递归调用之后越来越接近这个限制条件。