宏定义和内联函数的区别

    内联函数是代码被插入到调用者代码处的函数。如同 #define 宏,内联函数通过避免被调用的开销来提高执行效率,尤其是它能够通过调用(“过程化集成”)被编译器优化。 

    宏定义不检查函数参数,返回值什么的,只是展开,相对来说,内联函数会检查参数类型,所以更安全。

    内联函数和宏很类似,而区别在于,宏是由预处理器对宏进行替代,而内联函数是通过编译器控制来实现的。而且内联函数是真正的函数,只是在需要用到的时候,内联函数像宏一样的展开,所以取消了函数的参数压栈,减少了调用的开销。

    宏是预编译器的输入,然后宏展开之后的结果会送去编译器做语法分析。宏与函数等处于不同的级别,操作不同的实体。宏操作的是 token, 可以进行 token的替换和连接等操作,在语法分析之前起作用。而函数是语言中的概念,会在语法树中创建对应的实体,内联只是函数的一个属性。

既然有函数,为什么还要有宏定义和内联函数呢?

    原因是:

        <1>函数并不能完全替代宏,有些宏可以在当前作用域生成一些变量,函数做不到。

        <2>内联函数只是函数的一种,内联是给编译器的提示,告诉它最好把这个函数在被调用处展开,省掉一个函数调用的开销(压栈,跳转,返回)


何时使用内联函数?

    并不是你对每个函数声明为内联函数,它就会安妮预想的作为内联函数处理。

    当你的内联函数的函数体过大,或者存在循环,例如存在 for 循环,此时编译器会进行优化,放弃内联方式,二采用普通的方式调用函数,此时尽管你声明了内联函数,但其实是普通函数。

    

猜你喜欢

转载自blog.csdn.net/zhoujy1996/article/details/80219364