搬瓦工官网中国镜像站:https://bwh81.net(搬瓦工官方网站,放心访问)
搬瓦工官方中文网:https://bwh86.net
搬瓦工官网所有方案以及库存监控页面:https://bwh86.net/monitor
最新搬瓦工最大优惠力度优惠码(循环优惠6.58%):BWHNCXNVXV
搬瓦工新用户注册和图文购买教程:点击查看
内联函数是C ++的重要功能之一。那么,让我们首先了解为什么使用内联函数以及内联函数的目的是什么?
当程序执行函数调用指令时,CPU将存储该函数调用之后的指令的内存地址,将函数的参数复制到堆栈上,最后将控制权转移到指定的函数。然后,CPU执行功能代码,将功能返回值存储在预定义的存储位置/寄存器中,并将控制权返回给调用函数。如果函数的执行时间少于从调用者函数到被调用函数(被调用者)的切换时间,则这可能会成为开销。对于大型函数和/或执行复杂任务的函数,与函数运行所花费的时间相比,函数调用的开销通常很小。但是,对于小型的常用功能,进行函数调用所需的时间通常比实际执行函数代码所需的时间多得多。对于小功能,由于小功能的执行时间少于切换时间,因此会产生开销。
C ++提供了一个内联函数,以减少函数调用的开销。内联函数是在调用时在行中扩展的函数。调用内联函数时,将在内联函数调用时插入或替换内联函数的整个代码。此替换由C ++编译器在编译时执行。如果内联函数很小,则可以提高效率。
定义函数内联的语法为:
inline return-type function-name(parameters) { }
请记住,内联只是对编译器的请求,而不是命令。编译器可以忽略内联请求。在以下情况下,编译器可能不会执行内联:
1.如果函数包含循环。(对于while,do-while)
2.如果函数包含静态变量。
3.如果函数是递归的。
4.如果函数的返回类型不是void,并且return语句在函数体中不存在。
5.如果函数包含switch或goto语句。
内联函数具有以下优点:
1.不会发生函数调用开销。
2.调用函数时,还节省了push / pop变量在栈上的开销。
3.它还节省了从函数返回调用的开销。
4.内联函数时,可以使编译器对函数主体执行特定于上下文的优化。对于正常的函数调用,这种优化是不可能的。通过考虑调用上下文和被调用上下文的流程可以获得其他优化。
5.内联函数可能对于嵌入式系统有用(如果很小),因为内联函数所产生的代码少于函数调用的前导和返回。
内联函数的缺点:
1.内联函数中添加的变量消耗了额外的寄存器,在内联函数之后,如果要使用寄存器的变量数量增加了,这可能会增加寄存器变量资源利用的开销。这意味着当在函数调用点替换内联函数主体时,也会插入该函数使用的变量总数。因此,将用于变量的寄存器数量也将增加。因此,如果函数内联后的变量数急剧增加,则肯定会导致寄存器利用率增加。
2.如果使用过多的内联函数,则由于重复执行相同的代码,二进制可执行文件的大小将很大。
3.过多的内联也会降低指令高速缓存命中率,从而降低了从高速缓存到主存储器的指令获取速度。
4.如果有人更改了内联函数中的代码,则内联函数可能会增加编译时间开销,然后必须重新编译所有调用位置,因为编译器需要再次替换所有代码以反映更改,否则它将继续使用旧功能。
5.内联功能对于许多嵌入式系统可能没有用。因为在嵌入式系统中,代码大小比速度更重要。
6.内联函数可能会导致崩溃,因为内联可能会增加二进制可执行文件的大小。内存溢出会导致计算机性能下降。
下面的程序演示了如何使用内联函数。
内联函数和类:
也可以在类内部定义内联函数。实际上,该类内部定义的所有函数都是隐式内联的。因此,这里也应用了内联函数的所有限制。如果您需要在类中显式声明内联函数,则只需在类内部声明该函数,然后使用inline关键字在类外部对其进行定义。
例如:
上面的样式被认为是不好的编程样式。最好的编程风格是只在类内部编写函数原型,并将其指定为函数定义中的内联。
例如:
下面的程序演示了此概念:
宏有什么问题?
熟悉C语言的读者都知道C语言使用宏。预处理程序直接在宏代码内替换所有宏调用。建议始终使用内联函数而不是宏。根据C ++的创建者Bjarne Stroustrup博士所说,在C ++中,宏几乎从不需要,而且容易出错。在C ++中使用宏存在一些问题。宏无法访问班级的私人成员。宏看起来像函数调用,但实际上不是。
例:
C ++编译器检查内联函数的参数类型,并且正确执行了必要的转换。预处理程序宏无法执行此操作。另一件事是,宏由预处理器管理,内联函数由C ++编译器管理。
切记:确实,该类内部定义的所有函数都是隐式内联的,并且C ++编译器将对这些函数执行内联调用,但如果该函数是虚拟的,则C ++编译器将无法执行内联。原因是对虚拟函数的调用是在运行时而不是在编译时解决的。虚拟方式要等到运行时才运行,而内联方式要等到编译期间,如果编译器不知道将调用哪个函数,它如何执行内联?
要记住的另一件事是,仅当函数调用期间花费的时间比函数主体执行时间多时,才使函数内联。内联函数完全无效的示例:
上面的函数执行起来相对要花很长时间。通常,不应将执行输入输出(I / O)操作的功能定义为内联函数,因为它会花费大量时间。从技术上讲,show()函数的内联是有限的,因为I / O语句将花费的时间远远超过了函数调用的开销。
如果函数未内联扩展,则取决于使用的编译器,编译器可能会向您显示警告。像Java&C#这样的编程语言不支持内联函数。
但是在Java中,编译器可以在调用小型final方法时执行内联,因为final方法不能被子类覆盖,并且对final方法的调用在编译时就可以解决。在C#中,JIT编译器还可以通过内联小的函数调用来优化代码(例如,在循环中替换小函数的主体时)。
最后要记住的是,内联函数是C ++的宝贵功能。适当地使用内联函数可以提高性能,但是如果任意使用内联函数,则它们不能提供更好的结果。换句话说,不要指望程序有更好的性能。不要使每个函数都内联。最好使内联函数尽可能小。
免费领取学习资料及教程+QQ群:560434603
搬瓦工机房方案整理
搬瓦工目前提供了4个方案,包括搬瓦工KVM方案,搬瓦工CN2 GT方案,搬瓦工CN2 GIA-E方案和搬瓦工香港方案,每种方案有多种套餐配置,详细的配置和价格整理如下:套餐名称 | CPU | 内存大小 | 硬盘容量 | 每月流量 | 带宽 | 价格/年 | 购买链接 |
---|---|---|---|---|---|---|---|
搬瓦工CN2-E限量版(搬瓦工补货通知群(禁言,仅推送):903230558) | |||||||
CN2 GIA LIMITED EDITION | 1核 | 1 GB | 10 GB | 500 GB | 1 Gbps | $89.99 | 立即购买 |
搬瓦工CN2 GT方案 | |||||||
CN2 | 1核 | 1024 MB | 20 GB | 1000 GB | 1 Gbps | $49.99 | 立即购买 |
CN2 | 1核 | 2048 MB | 40 GB | 2000 GB | 1 Gbps | $99.99 | 立即购买 |
CN2 | 2核 | 4096 MB | 80 GB | 3000 GB | 1 Gbps | $199.99 | 立即购买 |
CN2 | 2核 | 8 GB | 160 GB | 5000 GB | 1 Gbps | $399.99 | 立即购买 |
CN2 | 3核 | 16 GB | 320 GB | 8000 GB | 1 Gbps | $799.99 | 立即购买 |
CN2大流量 | 3核 | 16 GB | 320 GB | 12000 GB | 1 Gbps | $899.99 | 立即购买 |
CN2大流量 | 3核 | 16 GB | 320 GB | 16000 GB | 1 Gbps | $1299.99 | 立即购买 |
搬瓦工CN2 GIA-E方案(可选搬瓦工DC9 CN2 GIA,搬瓦工DC6 CN2 GIA,搬瓦工日本大阪软银线路) | |||||||
CN2 GIA ECOMMERCE | 2核 | 1 GB | 20 GB | 1000 GB | 2.5 Gbps | $169.99 | 立即购买 |
CN2 GIA ECOMMERCE | 3核 | 2 GB | 40 GB | 2000 GB | 2.5 Gbps | $299.99 | 立即购买 |
CN2 GIA ECOMMERCE | 4核 | 4 GB | 80 GB | 3000 GB | 2.5 Gbps | $549.99 | 立即购买 |
CN2 GIA ECOMMERCE | 6核 | 8 GB | 160 GB | 5000 GB | 5 Gbps | $879.99 | 立即购买 |
CN2 GIA ECOMMERCE | 8核 | 16 GB | 320 GB | 8000 GB | 5 Gbps | $1599.99 | 立即购买 |
CN2 GIA ECOMMERCE | 10核 | 32 GB | 640 GB | 10000 GB | 10 Gbps | $2759.99 | 立即购买 |
CN2 GIA ECOMMERCE | 12核 | 64 GB | 1280 GB | 12000 GB | 10 Gbps | $5399.99 | 立即购买 |
搬瓦工香港方案 | |||||||
香港CN2 GIA | 2核 | 2048 MB | 40 GB | 500 GB | 1 Gbps | $899.99 | 立即购买 |
香港CN2 GIA | 4核 | 4096 MB | 80 GB | 1000 GB | 1 Gbps | $1559.99 | 立即购买 |
香港CN2 GIA | 6核 | 8192 MB | 160 GB | 2000 GB | 1 Gbps | $2999.99 | 立即购买 |
香港CN2 GIA | 6核 | 16384 MB | 320 GB | 4000 GB | 1 Gbps | $5899.99 | 立即购买 |
搬瓦工日本方案 | |||||||
日本CN2 GIA | 2核 | 2048 MB | 40 GB | 500 GB | 1.2 Gbps | $899.99 | 立即购买 |
日本CN2 GIA | 4核 | 4096 MB | 80 GB | 1000 GB | 1.2 Gbps | $1559.99 | 立即购买 |
日本CN2 GIA | 6核 | 8192 MB | 160 GB | 2000 GB | 1.2 Gbps | $2999.99 | 立即购买 |
日本CN2 GIA | 6核 | 16384 MB | 320 GB | 4000 GB | 1.2 Gbps | $5899.99 | 立即购买 |
搬瓦工KVM方案 | |||||||
KVM | 2核 | 1024 MB | 20 GB | 1 TB | 1 Gbps | $49.99 | 立即购买 |
KVM | 3核 | 2 GB | 40 GB | 2 TB | 1 Gbps | $99.99 | 立即购买 |
KVM | 4核 | 4 GB | 80 GB | 3 TB | 1 Gbps | $199.99 | 立即购买 |
KVM | 5核 | 8 GB | 160 GB | 4 TB | 1 Gbps | $399.99 | 立即购买 |
KVM | 6核 | 16 GB | 320 GB | 5 TB | 1 Gbps | $799.99 | 立即购买 |
KVM | 7核 | 24 GB | 480GB | 6 TB | 1 Gbps | $1,199.99 | 立即购买 |
还木有评论哦,快来抢沙发吧~