C++中内联函数inline的另一作用

本文介绍如何使用内联函数解决C++中因多个源文件包含同一头文件导致的函数重复定义问题。通过将函数定义置于类内并声明为内联,避免了链接阶段的错误。


将函数体直接放在类体总的是内联函数的隐式声明

在类中给出的函数实现具有文件内部局部作用域


内联函数不是在调用时发生控制转移,而是在编译时将函数体嵌入在每一个调用处。

    今天在coding时遇到多次定义一个函数而使ld返回错误的情况。大致过程如下:

    首先,在一个头文件中定义了一个类及其实现:

    test.h:

[cpp]  view plain copy
  1. #ifndef TEST_H  
  2. #define TEST_H  
  3. class A{  
  4.     public:  
  5.     void fun();  
  6. };  
  7. void A::fun(){  
  8. }  
  9. #endif  

    然后分别有两个文件:

a.cpp:

[cpp]  view plain copy
  1. #include"test.h"  
  2. void tt()  
  3. {  
  4. }  

b.cpp:

[cpp]  view plain copy
  1. #include<iostream>  
  2. #include"test.h"  
  3. using namespace std;  
  4. void tt();  
  5. int main()  
  6. {  
  7.     A a;  
  8.     tt();  
  9.     return 0;  
  10. }  
    而后,将a和b分别编译之后就会出错:


    想了想,是由于分开后在a.o和b.o中都分别定义了A的fun()函数,因此会发生冲突。

    这里一般的解决方法是将定义放到类定义当中去,即将test.h改为:

    test.h:

[cpp]  view plain copy
  1. #ifndef TEST_H  
  2. #define TEST_H  
  3. class A{  
  4.     public:  
  5.     void fun(){};  
  6. };  
  7.   
  8. #endif  

    再次进行编译链接:


    但是由于特殊原因,这里不方便这样做。

    想了半天,想到链接是全局符号的确定与定位,那么如果函数不是全局变量,不就不用链接了么。

    这里可以用内联函数!

    可以将test.h改为:

[cpp]  view plain copy
  1. #ifndef TEST_H  
  2. #define TEST_H  
  3. class A{  
  4.     public:  
  5.     void fun();  
  6. };  
  7. inline void A::fun(){  
  8. }  
  9. #endif  

测试后能正确编译链接,问题解决!

转载: http://blog.youkuaiyun.com/tobacco5648/article/details/7651073

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值