重新学习C语言 day4

函数

函数定义

在计算机科学中,子程序(英语: Subroutine, procedure, function, routine, method,
subprogram, callable unit ),是一个大型程序中的某部分代码, 由一个或多个语句块组
成。它负责完成某项特定任务,而且相较于其他代 码,具备相对的独立性。

库函数

C 语言的基础库中提供了一系列类似的库函数,方便程序员进行软件开发。
www.cplusplus.com
需要学会查询工具的使用:
MSDN(Microsoft Developer Network)
www.cplusplus.com
http://en.cppreference.com (英文版)
http://zh.cppreference.com (中文版)
英文很重要。最起码得看懂文献。

自定义函数

自定义函数的组成:

ret_type fun_name(para1, * ){
 statement;//语句项
}
//ret_type 返回类型
//fun_name 函数名
//para1    函数参数
#include <stdio.h>
//交换数字
void Swap(int *x, int *y){
    int temp = 0;
    temp = *x;
    *x = *y;
    *y = temp;
}

int main(){
    int num1 = 0;
    int num2 = 0;
    scanf("%d %d", &num1, &num2);
    Swap(&num1, &num2);
    printf("Swap: num1 = %d, num2 = %d\n ", num1, num2);
    return 0;
}

函数的参数

实际参数

真实传给函数的参数,叫实参。
实参可以是:常量、变量、表达式、函数等。
无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形
参。

形式参数

形式参数是指函数名后括号中的变量,因为形式参数只有在函数被调用的过程中才实例化(分配内
存单元),所以叫形式参数。形式参数当函数调用完成之后就自动销毁了。因此形式参数只在函数
中有效。
上述代码中的*x, *y 为形参,&num1, &num2为实参。
形参实例化之后其实相当于实参的一份临时拷贝

函数嵌套与链式访问

函数嵌套

#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>
#include <string.h>
int main()
{
    char arr[20] = "hello";
    int ret = strlen(strcat(arr,"bit")); //strcat:加字符串到后面
    printf("%d\n", ret);
    return 0;
}
#include <stdio.h>
int main()
{
    printf("%d", printf("%d", printf("%d", 43)));
    //结果是啥?
    //注:printf函数的返回值是打印在屏幕上字符的个数
    return 0;
}

函数声明及实现

函数声明

1. 告诉编译器有一个函数叫什么,参数是什么,返回类型是什么。但是具体是不是存在,函数
声明决定不了。
2. 函数的声明一般出现在函数的使用之前。要满足 先声明后使用
3. 函数的声明一般要放在头文件中的

函数实现

函数的定义是指函数的具体实现,交待函数的功能实现。
test.h 的内容
放置函数的声明
#ifndef __TEST_H__
#define __TEST_H__
//函数的声明
int Add(int x, int y);
#endif //__TEST_H__
test.c 的内容
放置函数的实现
#include "test.h"
//函数Add的实现
int Add(int x, int y){
 return x + y;
}

函数递归

递归定义

程序调用自身的编程技巧称为递归( recursion )。
递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接
调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问
题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程
序的代码量。
递归的主要思考方式在于:把大事化小。

递归条件

存在限制条件,当满足这个限制条件的时候,递归便不再继续。
每次递归调用之后越来越接近这个限制条件。
#include <stdio.h>
void print(int n){
    if(n > 9){
    print(n/10);
}
    printf("%d ", n % 10);
}
int main(){
    int num = 1234;
    print(num);
    return 0;
}
//输出1 2 3 4

  • 20
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值