如何解决Boost - 链接期间的多个定义
我有这两个类(我们称它们为 A
和 B
),它们都包含 boost/archive 和 boost/序列化文件。这些包括在我的 hpp 文件(带有标题保护)中,用于两个类中的每一个。类 A
(和代码库的其他部分)包含类 B
,因此重复完全相同的包含。
根据我的理解,boost 库中的头文件保护应该阻止库文件再次被包含在这里;但情况似乎并非如此。 我什至在包含块周围放置了另一个头部保护器,以确保它不会被多次包含;然而在链接时,我得到了一个多重定义的错误。
包含在类 A
中:
#ifndef _A_H
#define _A_H
// Other none boost includes for class A
#ifndef _BOOST_INCLUDES_
#define _BOOST_INCLUDES_
#include <boost/archive/binary_iarchive.hpp>
#include <boost/archive/binary_oarchive.hpp>
#include <boost/serialization/access.hpp>
#include <boost/serialization/export.hpp>
#include <boost/serialization/binary_object.hpp>
#include <boost/serialization/base_object.hpp>
#include <boost/serialization/vector.hpp>
#include <boost/serialization/string.hpp>
#endif
class A{/*...*/};
并且类 B
在其头文件中具有相同的包含块(和 _BOOST_INCLUDES_
保护)。代码的其他部分在某些时候也包含 class A
或 class B
,但问题源于此处包含的某些内容。
为什么会发生这种情况(我该如何解决)?为什么boost header 守卫不阻止这第二次包含?这是否与代码本身无关,而是构建问题?
Makefile 提取:
BOOST_ROOT := myPathToBoost/boost_1_75_0/
BOOST_LIBS := -L$(BOOST_ROOT)stage/lib/ -lboost_serialization
BOOST := -I $(BOOST_ROOT) $(BOOST_LIBS)
$(CM_OBJS): $(CM_SOURCES)
$(CC) $(FLAGS) -MMD $(BOOST) -c $(INCLUDES) -o $@ $< $(LIBS)
/usr/bin/ld: /projectPath/build/clientMain.o:(.bss+0x0): multiple deFinition of `boost::archive::detail::extra_detail::init_guid<EndGame>::g'; /projectPath/build/Register.o:(.bss+0x0): first defined here
对于每个包含都会重复此消息;文件名不同,::init_guid<X>
的内容也不同。
解决方法
确实将 const StoryDisplayScreen = props => {
const theStory = require('../data/TestStory.json')
const theArc = 'intro'
const storyText = () => {
theStory[theArc].story.forEach((paragraph,i) => {
<Text style={styles.body}>{paragraph}</Text>
})
}
return (
<View style={styles.screen}>
<ScrollView>
<View>
{storyText()}
</View>
<View style={styles.promptNextArcArea}>
<TouchableOpacity style={styles.promptNextArc}>
<Text style={styles.promptNextArcText}>What do you do?</Text>
</TouchableOpacity>
</View>
</ScrollView>
</View>
)
}
放在头文件中会导致在您将头文件包含到多个翻译单元(想想 .cpp 文件)中时会产生多个定义的符号。
如果没有你的代码,我在这个网站上有很多完整的例子。我会搜索“用户:85371 boost_class_export_key”:
- Trying to send an derived class through a boos::asio socket using boost::serialization
- Serialize Polymorph Interface
- BOOST_CLASS_EXPORT_* macros are not working like register_type()
- Boost serialization,loading an archived class by base type gives wrong data
- Boost Serialization - Exporting in multiple CPP files
- Why does boost::serialize not work despite everything seeming right? ("unregistered class")
他们中的大多数都有在线多文件现场演示并包含在答案文本中。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。