1

我有一堂课叫Time. 只有两个私有成员:int hoursint minutes。公共访问说明符仅包含加法、减法等功能。

但是有一个特定的功能不符合我想要的方式。它public在类中声明。

这样它编译:

Time Time::operator*(const int &mult)
{
   minutes = minutes*mult;
   hours = hours*mult + minutes/60;
   minutes %= 60;
   return *this;
}

但是,如果参数不是 na int,而是 afloatdouble怎么办?我想使用模板是最好的选择,而不是重载函数:

template <class T> Time Time::operator*(const T &mult)
{
   minutes = int(minutes*mult);
   hours = int(hours*mult) + minutes/60;
   minutes %= 60;
   return *this;
}

但是,以这种方式编写会产生编译错误:

error LNK2019: unresolved external symbol "public: class Time __thiscall Time::operator*<int>(int const &) " (??$?DH@Time@@QBE?AV0@ABH@Z) referenced in function _main

这意味着我不能将运算符重载与模板一起使用或什么?

谢谢
罗伯特

4

1 回答 1

0

模板就像函数的模式。在使用它们之前,它们必须被实例化。对于您的示例,您需要使用 T=int 对 Time::operator* 进行实例化,这是通过将函数中的每个 T 替换为 来获得的int

这种实例化有两种方式:

首先,有显式实例化,您必须在其中为要使用它的所有类型实例化模板。您的 operator* for T=int 的显式实例化如下所示:

template Time Time::operator*<int>(const int &mult);

编译器需要查看定义来实例化模板,所以这里模板化函数的实现必须在同一个文件或包含文件中,但您可以将显式实例化与模板的实现放在一个实现文件中。

另一种方法是隐式实例化,模板在使用时在调用方进行实例化。对于此方法,模板实现必须在您使用模板时可见。实现这一点的最简单方法是将模板实现放在声明模板的头文件中。

因此,您有两个选择,要么将 int 的显式实例化添加到实现文件中,要么将模板实现移动到头文件中。

于 2013-07-04T14:28:06.010 回答