C ++中的“未定义的符号”错误

时间:2012-07-25 01:19:25

标签: c++ templates compiler-errors

我昨天发布了这个。人们建议我应该使用Point.hPoint.cpp文件,因为我使用template。我为班级Point创建了单独的文件,但我仍然收到错误。

//Point.h
Point(T = 0, T = 0, string = "Deafault Point");
~Point();
T operator-(const Point<T> &);  

//Point.cpp
template < typename T >
Point<T>::Point(T x,T y, string name)
:X(x), Y(y), Name(name)
{
}

template < typename T >
Point<T>::~Point()
{
}

template < typename T>
T Point<T>::operator-(const Point<T> &rhs)
{
cout << "\nThe distance between " << getName() << " and " 
<< rhs.getName() << " = ";

return sqrt(pow(rhs.getX() - getX(), 2) + pow(rhs.getY() - getY(), 2));;
}

//main.cpp
#include <iostream>
#include <math.h>
#include "Point.h"

using namespace std;

int main () {

Point<double> P1(3.0, 4.1, "Point 1");
cout << P1;

Point<double> P2(6.4, 2.9, "Point 2");
cout << P2;

cout << (P2 - P1);
return EXIT_SUCCESS;
}

这就是我得到的:

Undefined symbols:
"std::basic_ostream<char, std::char_traits<char> >& operator<< <double (std::basic_ostream<char,  std::char_traits<char> >&, Point<double> const&)", referenced from:
  _main in main.o
  _main in main.o
"Point<double>::operator-(Point<double> const&)", referenced from:
  _main in main.o
"Point<double>::Point(double, double, std::basic_string<char, std::char_traits<char>, std::allocator<char> >)", referenced from:
  _main in main.o
  _main in main.o
"Point<double>::~Point()", referenced from:
  _main in main.o
  _main in main.o
  _main in main.o
  _main in main.o
ld: symbol(s) not found
collect2: ld returned 1 exit status

感谢任何帮助...

2 个答案:

答案 0 :(得分:7)

  

人们建议我应该使用Point.h和Point.cpp文件,因为我正在使用模板

无论谁提出这个都是错误的。模板的实现必须可见。

您可以实现与文件分开,但之后您还需要包含它。当您可以隐藏模板的实现时,唯一的情况是您知道特殊化并事先声明它们。 (这不适用于此处)

模板需要一个文件:

//Point.h

template <typename T>
struct Point
{
   Point(T = 0, T = 0, string = "Deafault Point");
   ~Point();
   T operator-(const Point<T> &);  
};

template < typename T >
Point<T>::Point(T x,T y, string name)
:X(x), Y(y), Name(name)
{
}

template < typename T >
Point<T>::~Point()
{
}

template < typename T>
T Point<T>::operator-(const Point<T> &rhs)
{
cout << "\nThe distance between " << getName() << " and " 
<< rhs.getName() << " = ";

return sqrt(pow(rhs.getX() - getX(), 2) + pow(rhs.getY() - getY(), 2));;
}

此外,标题中的裸string表示标题中也有using namespace std;。这是不好的做法,删除using指令并限定名称std::string

答案 1 :(得分:0)

关于模板类的所有已定义和已实现的代码都应该写在'.h'文件中,否则将是编译错误。