函数放在头文件中被多次包含的重定义问题以及原Makefile存在的问题

解决函数重定义问题
本文探讨了当头文件被多次包含时如何避免函数重定义错误,提供了三种解决方案:使用inline关键字、添加static修饰符或将函数放入类中,并分析了Makefile配置对编译的影响。

例如一个头文件headfile.h这样写

#pragma once

bool Func (){return true;}

在这个头文件被多个地方包含的时候就会出问题,链接时报错: (FuncB报重定义)
“fatal error LNK1169: 找到一个或多个多重定义的符号”

原因是,在headfile.h中定义了函数及其实现,如果被包含时,则会把函数实现放入包含的位置,被包含多次时,则会被放入多次,从而导致Func重定义。

那怕是在头文件中使用了#pragma once或是#ifdef __xxx /#define __xxx/#endif也不能解决这种问题。原因是每个.cpp的编译都是多独立的,对于每个cpp来说,都是包含了Func的声明和实现,所以在链接时就不清楚到底是链接哪一个同名函数了。

解决方法也很简单:

方法一: 添加inline标识,添加完inline标识后,函数的内容代码被直接解释到调用处了,链接时相当于不存在这个函数,也就不存函数重定义的情况。

Inline bool Func () {return true;}

方法二: 添加static标识

static bool Func () {return true;}

方法三: 放入到类中

class ClassA

{

public:

     bool Func () {return true;}

}

对于方法二与方法三,我个人猜测,对于静态函数和类,无论有多少文件包含它,也只会维护一份,链接时也就只能找到这一份,所以也是没有问题。
————————————————
版权声明:本文为CSDN博主「春夜喜雨」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/chunyexiyu/article/details/43673059

当然还有一个问题就是在维护开发一个新的引擎时,已经将头文件中定义的函数进行了删除,在另一个cpp中进行实现,但是编译的时候发现还是提示在原来的头文件中出现了重复定义的行为,经过检查发现原来维护的人员在写Makefile时不规范,重新进行sh make.sh的时候,以前编译好的.o文件并没有删除或者进行更新,导致编译的时候还是使用之前的那个.o文件,将工程中的所有.o文件进行删除之后就可以了

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值