ヘッダーファイルをPointXYZRGBAI.hに作成してLidarFile.cppとcore.cpp、エラーが複数のファイルで使用されるヘッダーファイル内の構造体の宣言により、アーキテクチャx86_64の重複シンボルが発生する
duplicate symbol _EIGEN_ALIGN_16 in:
CMakeFiles/core.dir/core.cpp.o
CMakeFiles/core.dir/LidarFile.cpp.o
ld: 1 duplicate symbol for architecture x86_64
とヘッダを発生するエラーが
#define PCL_NO_PRECOMPILE
#ifndef POINTXYZRGBAI_H
#define POINTXYZRGBAI_H
#endif
#include <pcl/point_types.h>
struct PointXYZRGBAI{
PCL_ADD_POINT4D;
union{
struct{
float intensity;
uint32_t rgba;
};
float data_c[4];
};
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
} EIGEN_ALIGN_16;
POINT_CLOUD_REGISTER_POINT_STRUCT(PointXYZRGBAI,
(float, x, x)
(float, y, y)
(float, z, z)
(float, intensity, intensity)
(uint32_t, rgba, rgba)
)
inline std::ostream& operator << (std::ostream& os, const PointXYZRGBAI& p){
os << "(" << p.x << ", " << p.y << ", " << p.z << " - " << p.intensity << " - " << p.rgba << ")";
return (os);
}
ある文句ているように見えると私はメモリの位置合わせのための私のヘッダ定義構造体でEIGEN_ALIGN_16を使用します。ヘッダーガードが複数のインクルードを防止する必要がある場合、EIGEN_ALIGN_16は重複したシンボルになるのはなぜですか?説明をありがとうございます。
良い答えに加えて、あなたの 'endif'はヘッダファイルの末尾になければなりません。そうでなければ役に立たないからです。 – Phil1970
'ヘッダ'ファイルは通常、宣言(型と名前、別名インタフェース)のみを持っています。定義(実装のすべての詳細)は通常、実装ファイルの末尾に.cまたは.cppを付けて使用します。 –