[英]Adding a template to a class, that's being used in a multiset
修复方法可能很简单,但是我找不到答案。 我的感谢和泪水将给您一个答案。
基本上,下面的代码在没有模板的情况下也可以正常工作(当然以T为基元),但是一旦我添加了模板,它就会说我的参数列表丢失了。 我认为这与声明有关,但是这些函数没有使用范围解析,至少不是以我熟悉的方式。 我该如何工作?
template<class T>
class Foo
{
public:
Foo(T s, int i) : Data(s), pri(i) {}
//Overload the relational operator so that the priority is compared.
bool operator < (const Foo<T>& n) const { return n.pri < pri; }
T getData() { return Data; }
int getId() { return pri; }
private:
T Data;
int pri;
};
这是主要的
int main(void)
{
set<Foo> s; //These should actually be multiset, but was trying to get it to
s.insert(Foo("C++", 9)); //work as a set before jumping to multiset
s.insert(Foo("Is ", 7));
s.insert(Foo("Fun ", 3));
set<Foo>::iterator p;
for (p = s.begin(); p != s.end(); p++)
{
Foo n = *p;
cout << "Id: " << n.getId() << "\t Data: " << n.getData() << endl;
}
return 0;
}
如果您很好奇,该程序应该采用字符串(或其他类型)以及优先级并对优先级进行排序,则该程序并不完整,但是我应该在程序中使用此Class,但是在将其转换为模板时被绊倒了。
std::set
期望为type 。
在引入模板部分之前, Foo
是一种类型。
现在这是模板类, Foo
不再是类型。 Foo<int>
是一种类型; Foo<std::string>
是一种类型; 不是Foo
。
所以
std::set<Foo<int>> s;
能行得通,
std::set<Foo> s;
给出一个错误。
当您声明class Foo {};
, Foo
是类的名称。 但是,当您声明template <class T> class Foo {};
, Foo
是模板的名称。 模板不是类:它是创建类的秘诀。 诸如Foo<int>
或Foo<char>
类的类。
似乎您想将std::string
存储在集合中的Foo
中,这意味着代码应如下所示:
int main(void)
{
set<Foo<string>> s; //These should actually be multiset, but was trying to get it to
s.insert(Foo<string>("C++", 9)); //work as a set before jumping to multiset
s.insert(Foo<string>("Is ", 7));
s.insert(Foo<string>("Fun ", 3));
set<Foo<string>>::iterator p;
for (p = s.begin(); p != s.end(); p++)
{
Foo<string> n = *p;
cout << "Id: " << n.getId() << "\t Data: " << n.getData() << endl;
}
return 0;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.