2

我已经实现了自己的容器:

template<typename T>
class MyContainer
{
    // body where in some point 2 elements of collection are compared (-1, 0 and 1 possible comparison results)
};

我想要做的是添加对函数对象的支持,就像在 std::set 中一样,可以像这样执行函数对象:

struct Comparator
{
    bool operator()(const char* s1, const char* s2) const
    {
        return strcmp(s1, s2) < 0;
    }
};

然后将其作为设置参数传递:

std::set<const char*, Comparator> SomeSet;

我不是日常的 C++ 程序员,所以我需要帮助来实现这一点。为了增加对此的支持,我必须做什么?我必须创建字段MyContainer才能在其中存储函数对象以在容器内的排序方法中使用它吗?

4

1 回答 1

0

我通过添加默认模板值并定义默认比较类来解决它:

template<typename T, class Compare = DefaultTreeOrder<T>>
class MyContainer
{
    private:
        Compare compare;
    public:
        MyContainer()
        {
            compare = Compare();
        }
};

哪里DefaultTreeOrder是:

template<typename T>
class DefaultTreeOrder 
{
    public:
        int operator()(T value1, T value2)
        {
            less<T> l;
            greater<T> g;

            if(l(value1, value2))
            {
               return 1;
            }
            else if(g(value1, value2))
            {
                return -1;
            }

            return 0;
        } 
};
于 2013-12-07T13:44:24.353 回答