• Effective C++ Item 30 inline里里外外


    本文为senlie原创。转载请保留此地址:http://blog.csdn.net/zhengsenlie


    Item 44 46


    1.将大多数 inlining 限制在小型、被频繁调用的函数身上。这可使日后的调试过程和二进制升级更easy,
    也可使潜在的代码膨胀问题最小化,使程序的速度提升机会最大化。


    2.inline是对编译器的一个申请。
    隐喻方式:将函数定义于 class 定义式内, 如成员函数或 friend 函数
    明白声明:在定义式前加keyword inline
    编译器会拒绝大过复杂的函数 inlining, 而全部对 virtual 函数的调用也都会使 inlining 落空。
    由于 virtual 意味 ”等待。直到执行期才确定调用哪个函数“, 而 inline 意味”执行前,先将调用动作替换为被调用函数的本体“。




    3.尽管编译器有意愿 inlining 某个函数。还是可能为该函数生成一个 outlined 函数本体。
    正常调用能够inlined, 通过函数指针的调用也许不被 inlined

    inline void f() {...} //如果编译器有意愿 inline "对f的调用"
    void (*pf)() = f; //pf指向 f
    //...
    f(); //这个调用将被 inlined,由于它是一个正常调用。

    pf();//这个调用也许不被 inlined,由于它通过函数指针达成。



    4.不要仅仅由于 function templates 出现的头文件,就将它们声明为 inline
    Inline 函数通常一定被置于头文件内,由于大多数建置环境在编译过程中进行inlining,而为了将一个“函数调用”
    替换为“被调用函数函数的本体”。嘎嘎必须知道那个函数长什么样子。


    Templates 通常也被置于头文件内,由于它一旦被使用,编译器为了将它详细化。须要知道它长什么样子。
    但 Template 的详细化与 inlining无关。不要仅仅由于 function templates 出现的头文件,就将它们声明为 inline。


    5.inline函数f:一旦改变f,全部用到f的client面程序都必须又一次编译
    non-inline函数:一旦改变f,client仅仅需又一次连接。

  • 相关阅读:
    layui的table使用,二
    将字符串中的以某个字符间隔放到数组中
    oracle中的 函数应用
    spring 的3种常用的注入方式
    写一个方法,输入两个正整数,输出在两个正整数范围内即被3整除,又被7整除的正整数
    Myeclipse 10.7配置egit及导入项目
    Plsqi安装
    web项目引入js包时,报syntax error on token
    java笔试面试题总结
    web.xml中的配置
  • 原文地址:https://www.cnblogs.com/claireyuancy/p/6930824.html
Copyright © 2020-2023  润新知