1

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

    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>

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

谢谢

4

3 回答 3

4

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

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

std::strings 也有成员函数和类型别名,允许它们被 C++ 标准库的通用算法使用,所以上面的方法在 is 时也应该_Type有效std::string

于 2013-04-12T13:45:20.420 回答
0

试试这个为你的模板定义:

template <typename _Type, typename _Comparator = equal_to<_Type> >
于 2013-04-12T13:45:44.990 回答
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;
};
于 2013-04-12T13:56:30.820 回答