宏和内联

宏和内联

1)在C 程序中,可以用宏代码提高执行效率。宏代码本身不是函数,但使用起来象函

数。预处理器用复制宏代码的方式代替函数调用,省去了参数压栈、生成汇编语言的CALL

调用、返回参数、执行return 等过程,从而提高了速度。使用宏代码最大的缺点是容易

出错,预处理器在复制宏代码时常常产生意想不到的边际效应。

2)对于C++ 而言,使用宏代码还有另一种缺点:无法操作类的私有数据成员。

3C++ 的“函数内联”是如何工作的。对于任何内联函数,编译器在符号表里放入函数的声明(包括名字、参数类型、返回值类型)。如果编译器没有发现内联函数存在错误,那么该函数的代码也被放入符号表里。在调用一个内联函数时,编译器首先检查调用是否正确(进行类型安全检查,或者进行自动类型转换,当然对所有的函数都一样)。如果正确,内联函数的代码就会直接替换函数调用,于是省去了函数调用的开销。这个过程与预处理有显著的不同,因为预处理器不能进行类型安全检查,或者进行自动类型转换。假如内联函数是成员函数,对象的地址(this)会被放在合适的地方,这也是预处理器办不到的。

4C++ 语言的函数内联机制既具备宏代码的效率,又增加了安全性,而且可以自由操

作类的数据成员。

定义和内联函数都是C++中用于代码优化的机制,但它们有一些区别。 1. 编译时机: - 定义:定义是在预处理阶段进行替换的,编译器会将定义的地方直接替换为相应的代码。因此,定义的替换是在编译前进行的。 - 内联函数:内联函数是在编译阶段展开的,编译器会将内联函数的代码插入到每个调用的地方。因此,内联函数的展开是在编译时进行的。 2. 编译器处理方式: - 定义:定义是文本替换,没有类型检查和语法分析。它只是简单地将定义的地方替换为相应的代码。因此,定义不会进行参数类型检查和错误提示。 - 内联函数:内联函数是真正的函数调用,会进行类型检查和语法分析。编译器会将内联函数的代码插入到调用位置,并进行相应的优化。因此,内联函数具有更好的类型安全性和错误检查。 3. 可读性和调试: - 定义:定义的展开结果可能比较复杂,不易阅读和调试。因为定义是简单地进行替换,很难在调试过程中跟踪定义的具体执行流程。 - 内联函数:内联函数的代码会直接插入到调用位置,代码比较清晰,易于阅读和调试。在调试过程中可以准确地跟踪内联函数的执行流程。 4. 作用范围: - 定义:定义是全局的,可以在任何地方使用和修改。它没有作用域的概念。 - 内联函数:内联函数是与类或命名空间相关的,有作用域的概念。内联函数只能在声明的作用域内访问和调用。 总体而言,内联函数相对于定义来说更安全、更可控,具有更好的可读性和调试性。定义适用于简单的代码替换,而内联函数适用于需要类型检查和语法分析的优化场景。然而,使用内联函数也会增加代码体积,因为每个调用点都会插入一份函数体的副本。因此,在使用内联函数时需要权衡代码大小和性能优化的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值