【GNU笔记】内联函数与宏一样快 An Inline Function is As Fast As a Macro

2024-06-22 03:58

本文主要是介绍【GNU笔记】内联函数与宏一样快 An Inline Function is As Fast As a Macro,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内联函数与宏一样快 An Inline Function is As Fast As a Macro

通过声明内联函数,你可以指示 GCC 更快地调用该函数。GCC 可以实现这一点的一种方法是将该函数的代码集成到其调用者的代码中。这通过消除函数调用开销使执行速度更快;此外,如果任何实际参数值是常量,则它们的已知值可能允许在编译时进行简化,因此不需要包含所有内联函数的代码。对代码大小的影响是难以预测的;根据具体情况,使用内联函数的目标代码可能更大或更小。你还可以指示 GCC 尝试使用选项 -finline-functions 将所有“足够简单”的函数集成到它们的调用者中。

GCC 实现了声明函数内联的三种不同语义。一种是 -std=gnu89 或者 -fgnu89-inline 或者当gnu_inline 属性出现在所有内联声明中,另一种是 -std=c99 或者 -std=gnu99(没有 -fgnu89-inline),第三种是在编译 C++ 时使用。

要声明一个内联函数,请在其声明中使用inline关键字,如下所示 :

 static inline intinc (int *a){(*a)++;}

如果你正在编写要包含在 ISO C89 程序中的头文件,需要写 __inline__而不是inline. 请参阅替代关键字(Alternate Keywords)。

这三种类型的内联在两种重要情况下表现相似:当 inline 关键字用于 static 函数时,如上面的示例,以及当函数首次声明时不使用 inline 关键字,然后用 inline 定义,如下所示:

 extern int inc (int *a);inline intinc (int *a){(*a)++;}

在这两种常见情况下,程序的行为就像你没有使用inline关键字一样,除了它的速度。

当一个函数同时是 inline 和 static 时,如果对该函数的所有调用都集成到调用者中,并且从不使用函数的地址,则永远不会引用该函数自己的汇编代码。在这种情况下,GCC 不会实际输出函数的汇编代码,除非你指定选项 -fkeep-inline-functions 。 一些调用由于各种原因不能被集成(特别是函数定义之前的调用不能被集成,定义中的递归调用也不能被集成)。如果有一个非集成调用,那么该函数像往常一样被编译为汇编代码。如果程序引用了函数的地址,该函数也必须像往常一样编译,因为它不能被内联。

请注意,函数定义中的某些用法可能使其不适合内联替换。这些用法包​​括:可变参数(varargs)的使用、alloca 的使用、可变大小数据类型(variable sized data types)的使用(请参阅可变长度(Variable Length))、计算 goto (computed goto)的使用(请参阅作为值的标签(Labels as Values))、非局部 goto (nonlocal goto)的使用和嵌套函数(请参阅嵌套函数(Nested Functions))。当标记为 inline 的函数不能被替换时,使用 -Winline 将发出警告,并给出失败的原因。

根据 ISO C++ 的要求,GCC 认为在类中定义的成员函数被标记为内联,即使它们没有使用inline 关键字显式声明。你可以用 -fno-default-inline覆盖它; 请参阅Options Controlling C++ Dialect。

GCC 在不优化时不会内联任何函数,除非你为函数指定了 always_inline 的属性,如下所示:

 /* Prototype.  */inline void foo (const char) __attribute__((always_inline));

本节的其余部分是特定于 GNU C89 内联。

当内联函数不是 static 时,编译器必须假设可能有来自其他源文件的调用;由于一个全局符号在任何程序中只能定义一次,因此不能在其他源文件中定义该函数,因此不能集成其中的调用。因此,非 static 内联函数总是按照通常的方式进行编译。

如果在函数定义中同时指定 inlineextern ,则该定义仅用于内联。在任何情况下,该函数都不会单独编译,即使你显式地引用它的地址也是如此。这样的地址变成了外部引用,就像你只声明了函数,而没有定义它一样。

这种 inlineextern 的组合几乎具有宏的效果。使用它的方法是将函数定义放在带有这些关键字的头文件中,然后将定义的另一个副本(缺少 inline and extern )放在库文件中。头文件中的定义将导致大多数函数调用被内联。如果该函数的任何使用仍然存在,它们将引用库中的单个副本。

Inline - Using the GNU Compiler Collection (GCC)


[参考资料]

5.36 An Inline Function is As Fast As a Macro

本文链接:https://blog.csdn.net/u012028275/article/details/124208461

这篇关于【GNU笔记】内联函数与宏一样快 An Inline Function is As Fast As a Macro的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083226

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字