例如一个头文件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文件进行删除之后就可以了
解决函数重定义问题
本文探讨了当头文件被多次包含时如何避免函数重定义错误,提供了三种解决方案:使用inline关键字、添加static修饰符或将函数放入类中,并分析了Makefile配置对编译的影响。
3298

被折叠的 条评论
为什么被折叠?



