inline内联函数

一句话总结

inline 是让编译器把函数 "展开" 到调用处的建议,目的是用代码体积换执行速度适合简短且频繁调用的函数。inline 会让编译器会尝试把函数代码直接 "复制粘贴" 到调用它的地方,而不是跳转到函数定义处执行。

举例

想象你写文章时,经常需要用到 "世界上最高的山峰是珠穆朗玛峰" 这句话。有两种写法:

  1. 普通函数式:每次需要时,都写 "参见附录 A",然后在附录 A 里写完整句子。
  2. inline 式:每次需要时,直接把完整句子写在当前位置。

普通函数 vs inline 函数(代码对比)

假设我们要实现一个简单的 "求两数之和" 功能:

1. 普通函数(无 inline)
cpp 复制代码
// 函数定义(像"附录A")
int add(int a, int b) {
    return a + b;
}

// 调用处
int main() {
    int x = 10, y = 20;
    int result = add(x, y);  // 这里会跳转到add()函数的位置执行
    return 0;
}

执行过程

调用 add(x,y) 时,程序会先暂停当前工作,保存现场(如寄存器数据),跳转到 add 函数的代码处执行,计算完成后再跳转回来,恢复现场。这个过程有额外开销。

2. inline 函数(有 inline)
cpp 复制代码
// inline函数定义(像"直接写完整句子")
inline int add(int a, int b) {
    return a + b;
}

// 调用处
int main() {
    int x = 10, y = 20;
    int result = add(x, y);  // 编译器可能直接替换为:int result = x + y;
    return 0;
}

执行过程

编译器看到 inline 后,会尝试把 add(x,y) 直接替换成 x + y,省去了函数调用的跳转和现场保存开销,就像直接写 x + y 一样高效。

为什么要用 inline

  • 优点:减少函数调用的 "额外开销"(尤其适合频繁调用的短函数)。比如循环中调用的小函数,内联后能明显提速。
  • 缺点:如果函数体很大(比如几十行代码),内联会导致代码重复 "复制粘贴",使最终的程序体积变大(代码膨胀),反而可能降低效率。

关键注意点:

  1. 编译器说了算inline 只是 "建议",不是 "命令"。如果函数体复杂(有循环、递归等),编译器会无视 inline,按普通函数处理。
  2. 通常放头文件inline 函数的定义需要让编译器在调用处 "看得到 ",所以一般写在头文件里(普通函数通常只在头文件声明,源文件定义)。
  3. 适合短函数:只有一两行的简单函数(如求最大值、交换变量)才适合内联,长函数内联反而不好。
相关推荐
Ray Liang1 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
颜酱1 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
Java水解1 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SimonKing5 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean5 小时前
Jackson View Extension Spring Boot Starter
java·后端
Seven976 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
皮皮林55116 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河16 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
地平线开发者17 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮17 小时前
大模型连载2:初步认识 tokenizer 的过程
算法