2009-12-28 114 views
1

我有一个类'Vector3',它是编译成功。它包含非朋友功能和朋友功能,例如,当Vector3是第二个操作数时,过载*和< <操作符。问题是我无法链接到任何朋友功能,无论是运算符超载或不。所以我可以确认该错误不是特定于操作员重载的。 ++命令用于连接的g是如下(请参阅Makefile文件末),链接到朋友函数时出错

g++ -Wall -W -I./ -g -o main.out main.o Vector3.o 

这给了下面的错误,

main.cpp:7: undefined reference to `operator*(double, Vector3 const&)' 
main.cpp:9: undefined reference to `mag(Vector3 const&)' 
main.cpp:10: undefined reference to `operator<<(std::basic_ostream<char, std::char_traits<char> >&, Vector3 const&)' 

下面是我的源文件中的相关代码。我遵循为每个课程分别制作.hpp和.cpp的做法。

/* file Vector3.hpp */ 
struct Vector3 { 
    ... 
    Vector3 operator*(const double k) const; 
    friend Vector3 operator*(const double k, const Vector3 &vec); 
    double magnitude() const; 
    friend double mag(const Vector3 &vec); 
    friend std::ostream& operator<<(std::ostream& output, const Vector3 &vec); 
    ... 
} 

/* file Vector3.cpp */ 
Vector3 operator*(const double k, const Vector3 &vec) { 
    ... 
} 

inline double mag(const Vector3 &vec) { 
    ... 
} 

std::ostream& operator<<(std::ostream& output, const Vector3 &vec) { 
    ... 
} 

/* file main.cpp */ 
#include "Vector3.hpp" 
int main() { 
    Vector3 M(1, 1, 1); 
    M = M * 2.0;    // own operator* links successfully 
    M = 10.0 * M;    // friend operator* doesn't link 
    double m = M.magnitude(); // own function magnitude() links successfully 
    double n = mag(M);  // friend function mag() doesn't link 
    std::cout << M;   // friend operator<< doesn't link 
} 

最后,这是我的Makefile。

CXX   = g++ 
CXXFLAGS = -Wall -W $(INCPATH) -g 
INCPATH  = -I./ 
OBJS  = main.o Vector3.o 

main.out: $(OBJS) 
$(CXX) $(CXXFLAGS) -o [email protected] $(OBJS) $(LIBPATH) 

main.o: main.cpp 
Vector3.o: Vector3.cpp 

clean: 
rm -f $(OBJS) main.out 

最奇怪的是,如果我包括Vector3.cpp文件,以及在main.cpp中,然后从OBJS Makefile中删除Vector3.o,程序链接成功。我无法理解这一点。请帮帮我!!

+0

你能复制并粘贴vector3.hpp和vector3.cpp的全部内容吗? – 2009-12-28 02:17:55

+0

这个谜题有很多部分都是缺失的。 Vector3.hpp是否有头部守卫? Vector3.cpp是否包含“Vector3.hpp”?有没有文件包含?如果有太多的代码将所有这些问题都放在这个问题上,你可以制作一个更小的程序来显示相同​​的错误吗? – 2009-12-28 02:36:27

回答

1

朋友的定义operator*使用fp_type而朋友声明使用double作为第一个参数。如果fp_typedouble的typedef名称,则这只能按预期工作。你确定fp_type实际上代表double?我无法从您发布的代码中看到它。

mag的问题很明显:您在.cpp文件中将其定义为inline。内联函数定义在使用它们的任何地方都必须是可见的,这意味着它们通常应该放在头文件中。

+0

没关系。我发现我的错误,并将很快删除这个问题:) – Aamir 2009-12-28 02:36:56

+2

@Aamir我有一个类似的问题,这将是很好,如果你发布的解决方案,你的问题。除非这个答案是......但是为什么说“没关系”呢? – Steve 2014-08-12 17:28:08