0

要拆开一对,可以做到以下几点

boost::bind(&std::pair::second, _1); // returns the value of a pair

如何使用不同容器的组合,如何访问嵌套对?

例如,当我想将向量划分为包含在补充地图中的项目和未包含在补充地图中的项目时,我使用了以下内容:

typedef int DWORD; typedef std::pair<std::string, bool> user_info; 
typedef std::map<DWORD, user_info> USER_MAP; 
typedef std::vector<DWORD> VEC_STAFF; 
VEC_STAFF::iterator it = std::partition(
   Staff.begin(), Staff.end(), 
  (bind(&USER_MAP::find, m_Users, _1) != m_Users.end()));

现在我有第二个问题 - 在应用程序运行期间,user_info 的状态布尔值可以更改,稍后我想用状态布尔值为 true 的项目重新分区向量,而不仅仅是包含在补充地图中.

但是,我似乎在访问嵌套对的第二项时遇到了问题。

我尝试了以下方法,但似乎无法访问嵌套对!

VEC_STAFF::const_iterator itCurEnd = partition(Staff.begin(), Staff.end(),
     bind(&USER_MAP::value_type::second::second, 
     bind(&USER_MAP::find, &m_Users, _1)) == true);
4

2 回答 2

4

不确定我是否了解那里发生的事情,但通常当我开始遇到绑定问题时,我会放弃并实现一个仿函数。这可能会简化您的情况。

对我来说,下面的内容比多层次绑定更容易阅读

template <class Arg>
struct Whatever : public std::unary_function<Arg, bool>
{
    bool operator()(const Arg &arg1) const {
        //logic here
    } 
};

Whatever<???> functor;
std::partition(Staff.begin(), Staff.end(), functor);
于 2009-09-22T13:14:19.143 回答
1

您使用的语法显然不起作用。第一个“::second”已经表示非静态成员而不是类型。如果一对中有一对,则可能必须使用两个绑定调用:

typedef std::pair< int, bool > foo_t;
typedef std::pair< int, foo_t > bar_t;
.....

bind( &foo_t::second, bind(&bar_t::second,
    bind( &USER_MAP::find, _1 )
) )

(我没有测试这个。也许这就是你想要的)

但是在我看来,如果绑定的三个级别是相当具有挑战性的。

编辑:这个怎么样?

template<typename Iter, typename Return>
struct deref_2nd_2nd : std::unary_function<Iter, Return> {
    Return operator()(Iter const& it) const {
        return (*it).second.second;
    }
};

.....

bind(
    deref_2nd_2nd<USER_MAP::iterator,bool>(),
    bind( &USER_MAP::find, _1 )
)
于 2009-09-22T13:13:40.813 回答