各种类型的默认模板参数

时间:2013-04-12 13:39:35

标签: c++ templates

我正在尝试创建一个程序,我必须使用模板,我现在有点困难了。这是我的代码的一部分:

    template <typename _Type, typename _Comparator = equal_to</*char*/> >
        class CSearch {
public:
    CSearch();
    CSearch(const _Comparator & cmp);
    void Add(int id,
            const _Type & needle);
    set<int> Search(const _Type & hayHeap) const;
private:

    struct CSElem {
        int id;
        _Type sekvence;
    };
    vector<CSElem> data;
    _Comparator comp;
};

template <typename _Type, typename _Comparator>
CSearch<_Type, _Comparator>::CSearch() {
    comp = _Comparator();
}

.......

template <typename _Type, typename _Comparator>
void CSearch<_Type, _Comparator>::Add(int id, const _Type& needle) {
    CSElem temp;

    .....

    data.push_back(temp);
}

template <typename _Type, typename _Comparator>
set<int> CSearch<_Type, _Comparator>::Search(const _Type& hayHeap) const {
typename _Type::const_iterator j, t;

   ...... //trying to find out which items of the variable data are part of hayHeap

                    if (comp(*t, *j)) {
                        ......
                    }

   ......

}

/*
 *
 */
int main(int argc, char** argv) {
    CSearch <string> test1;
    test1 . Add(0, "hello");
    test1 . Add(1, "world");
    test1 . Search("hello world!");

    CSearch <vector<int> > test2;

....

}

所以问题是当我没有向模板提供第二个参数时,比较器对于存储在测试变量中的类型应该是equal_to,所以对于字符串它应该是

equal_to<char>

或用于向量的向量

equal_to<int>

我已经考虑了很长一段时间,但仍然没有弄清楚如何声明模板或其他什么,所以它具有前面提到的功能。 如果有人能给我一个提示或如何解决这个问题的例子,我会很高兴。

由于

3 个答案:

答案 0 :(得分:4)

您可以使用模板签名中的先前模板参数来形成后续模板参数的默认参数。此外,您可以利用以下事实:所有标准容器都为所包含元素的类型定义value_type别名:

template <typename _Type, 
          typename _Comparator = equal_to<typename _Type::value_type> >
//                                                      ^^^^^^^^^^^^

std::string还有成员函数和类型别名,允许它们被C ++标准库的通用算法使用,因此上述内容在_Typestd::string时也适用。

答案 1 :(得分:0)

尝试使用此模板定义:

template <typename _Type, typename _Comparator = equal_to<_Type> >

答案 2 :(得分:0)

您还可以将_ Container设为模板模板参数。

template <typename _Type, template <typename> class _Comparator = equal_to > 
class CSearch {
public:
    typedef typename _Type::value_type elem_type;
    CSearch();
    CSearch(const _Comparator<elem_type> & cmp);
    void Add(int id,
            const _Type & needle);
    set<int> Search(const _Type & hayHeap) const;
private:

    struct CSElem {
        int id;
        _Type sekvence;
    };
    vector<CSElem> data;
    _Comparator<elem_type> comp;
};