2

我有一个包含std::setof 的类boost::weak_ptr<T>。我有两个函数 begin() 和 end() 将迭代器返回到容器。但是,我不希望客户能够修改T. 简单地返回 a 是const_iterator行不通的,因为T指向的boost::weak_ptr是可编辑的。

我想要做的是返回一个const_iteratorto std::set<boost::weak_ptr<T const> >。铸造 fromstd::set<boost::weak_ptr<T> >::const_iterator不起作用。有没有办法得到我想要的行为?

4

1 回答 1

5

您可以编写一个转换迭代器来将 转换weak_ptr<T>weak_ptr<const T>. 由于您已经在使用 Boost,因此可以使用boost::transform_iterator

#include <boost/iterator/transform_iterator.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/weak_ptr.hpp>

#include <set>

// Functor to transform a weak_ptr<T> to a weak_ptr<const T>
template <typename T>
struct make_weak_ptr_const
    : std::unary_function<boost::weak_ptr<T>, boost::weak_ptr<const T> >
{
    boost::weak_ptr<const T> operator()(const boost::weak_ptr<T>& p) const
    {
        return p;
    }
};

struct S { };

// Container demonstrating use of make_weak_ptr_const:
struct my_awesome_container
{
    typedef std::set<boost::weak_ptr<S> > BaseSet;
    typedef BaseSet::const_iterator       BaseIterator;

    typedef boost::transform_iterator<
                make_weak_ptr_const<S>, 
                BaseIterator
            > iterator;

    iterator begin() const 
    {
        return TransformedIterator(data.begin());
    }

    iterator end() const
    {
        return TransformedIterator(data.end());
    }

    std::set<boost::weak_ptr<S> > data;
};

如果您不想使用boost::transform_iterator,那么编写自己的内容是一项简单的任务。我在另一个问题的回答中展示了如何做到这一点。

于 2011-03-26T18:57:54.303 回答