C语言特殊函数

静态函数

背景知识:普通函数都是跨文件可见的,即在文件 a.c 中定义的函数可以在 b.c 中使用。

静态函数:只能在定义的文件内可见的函数,称为静态函数。

语法

复制代码
staitc void f(void) // 在函数头前面增加关键字 static ,使之成为静态函数
{
    // 函数体
}

要点:

  • 静态函数主要是为了缩小函数的可见范围,减少与其他文件中重名函数冲突的概率。
  • 静态函数一般被定义在头文件中,然后被各个源文件包含。

递归函数

递归概念:如果一个函数内部,包含了对自身的调用,则该函数称为递归函数。

递归问题:

  • 阶乘。
  • 幂运算。
  • 字符串翻转。

要点:

  • 只有能被表达为递归的问题,才能用递归函数解决。
  • 递归函数必须有一个可直接退出的条件,否则会进入无限递归。
  • 递归函数包含两个过程,一个逐渐递进的过程,和一个逐渐回归的过程。

示例:依次输出 n 个自然数。

思路:先输出前面的 n-1 个自然数,再输出最后一个自然数 n 。而要输出前面的 n-1 个自然数,递归调用自身即可。

复制代码
// 该函数的功能:依次输出 n 个自然数
void f(int n) 
{
    if(n < 0)          // 1,当满足此条件时,不再进行递归。
        return;
        
    f(n-1);            // 2,递归调用自己,输出前 n-1 个数
    printf("%d\n", n); // 3,输出最后一个自然数 n
}

递归调用时,函数的栈内存的变化如下图所示。可见,随着递归函数的层层深入,栈空间逐渐往下增长,如果递归的层次太深,很容易把栈内存耗光。

层层递进时,问题的规模会随之减小,减小到可直接退出的条件时,函数开始层层回归。

递归调用时栈内存的变化

回调函数(钩子函数)

概念:函数实现方不调用该函数,而由函数接口提供方间接调用的函数,称为回调函数。

示例:系统中的信号处理,是一个典型的利用回调函数的情形。

要点:

  • 示例中函数 sighandler 是回调函数。
  • signal() 将函数回调函数传递给内核,使得内核可以在恰当的时机回调 sighandler。
  • 应用开发者和内核开发者只要约定好回调函数的接口,即可各自开发,进度互不影响。
相关推荐
想放学的刺客42 分钟前
单片机嵌入式嵌入式试题(第16期):硬件可靠性设计与复杂状态机架构设计
c语言·stm32·单片机·嵌入式硬件·物联网
code_li44 分钟前
聊聊支付宝架构
java·开发语言·架构
少控科技1 小时前
QT高阶日记01
开发语言·qt
无限进步_1 小时前
【C++】大数相加算法详解:从字符串加法到内存布局的思考
开发语言·c++·windows·git·算法·github·visual studio
“抚琴”的人1 小时前
C#上位机工厂模式
开发语言·c#
巨大八爪鱼2 小时前
C语言纯软件计算任意多项式CRC7、CRC8、CRC16和CRC32的代码
c语言·开发语言·stm32·crc
C+-C资深大佬2 小时前
C++ 数据类型转换是如何实现的?
开发语言·c++·算法
木千2 小时前
Qt全屏显示时自定义任务栏
开发语言·qt
浅念-2 小时前
链表经典面试题目
c语言·数据结构·经验分享·笔记·学习·算法
2501_944424122 小时前
Flutter for OpenHarmony游戏集合App实战之俄罗斯方块七种形状
android·开发语言·flutter·游戏·harmonyos