我想创建不同类型的容器,我想用SortedContainer类对它们进行排序 . (我现在不想使用像std :: sort()这样的函数 .
std::deque<int> d; d.push_back(2); d.push_back(1);
SortedContainer<int> sc1(d.begin(), d.end());
在SortedContainer类中,我想创建一个复制构造函数,它处理容器的迭代器(d.begin()和d.end()) .
但是,如果我创建另一种类型的STL容器,我想做同样的事情 .
std::vector<int> v; v.push_back(2); d.push_back(1);
SortedContainer<int> sc2(v.begin(), v.end());
在这种情况下,我使用std :: vector而不是std :: deque . 所以基本上,它将是一个模板构造函数 .
template <class T>
class SortedContainer
{
//...
public:
SortedContainer(template_iterator begin, template_iterator end)
{
//...
}
};
我知道如果我将类template_iterator添加为模板参数,它会很好用 .
SortedContainer<int, std::deque::const_iterator> sc1(d.begin(), d.end());
但是在实例化SortedContainer类时我没有't want to tell the containers'类型 . 我想在将container.begin()和container.end()传递给它的构造函数时找到它 .
我已经尝试过使用std :: function和其他一些方法,但它们都没有用 .
3 回答
您可以将该功能设置为模板,而不是将模板添加到类中 .
变
所以现在函数将除了任何类型,但你使用名称
Iterator
自我文档,该类型应该是一个迭代器 . 请注意,由于这是一个构建的SOP,它应该受到SFINAE的约束,因此它不会过于宽泛 .您可以创建一个
make_sorted_container
函数来为您进行演绎:它可以使用如下:
wandbox example
在C 17中,class template deduction将允许构造函数推导出模板参数 . 在这种情况下,您需要一个扣除指南:
可以像这样使用:
wandbox example
我将假设您的已排序容器的内部排序表示不依赖于用于初始化它的容器的类型 . 然后你需要做的就是模板构造函数: