1

我有一个由具有以下类型定义的地图组成的向量:

std::map< int, std::vector<int> >

因此,向量本身的定义是:

std::vector< std::map< int, std::vector<int> > >

现在我正在创建一个整数向量并将其插入到带有整数键的映射中,并将映射本身添加到外部向量中:

    std::map<int, std::vector<int> > vDescriptorAtom;
    vDescriptorAtom.insert( std::make_pair(498, vListOfIds) );
    messageDescriptorVector.push_back( vDescriptorAtom );

其中 vListOfIds 本身是一个整数向量。

在稍后阶段,我想提取内部向量并与我拥有的另一个向量进行比较。我的印象是我可以轻松地使用==两个向量之间的运算符进行比较。但我在这样做时遇到了一些麻烦。

我试过了:

               for ( int i = 0 ; i <= messageDescriptorVector.size(); i++ )
                {    
                    if ( current_tag_stack == (messageDescriptorVector.at(i))->second )
                    {
                        vFoundMatchingDescriptor = true;
                        break;
                    }
                } 

请注意,current_tag_stack 具有以下定义:

std::vector<int> current_tag_stack;

但我收到此错误:

base operand of â->â has non-pointer type âstd::map<int, std::vector<int, std::allocator<int> >, std::less<int>, std::allocator<std::pair<const int, std::vector<int, std::allocator<int> > > > >â

我究竟做错了什么 ?

编辑

正如评论所建议的,我试图访问我存储在地图中的向量:messageDescriptorVector.at(i).second但它给了我这个错误:âclass std::map<int, std::vector<int, std::allocator<int> >, std::less<int>, std::allocator<std::pair<const int, std::vector<int, std::allocator<int> > > > >â has no member named âsecondâ

4

3 回答 3

4

messageDescriptorVector.at(i)是一张地图。您必须获取该地图的一个元素,以便获取它second并将其与您的参考向量进行比较。所以你需要多一层迭代。

for ( int i = 0 ; i < messageDescriptorVector.size(); i++ )
{
  auto& m = messageDescriptorVector.at(i); // m is a map<int, vector<int>>

  for (auto& p : m) // p is a ref to pair<int, vector<int>>
  {
    if ( current_tag_stack == p.second )
    {
      // do something ....

要不就

for (auto& m : messageDescriptorVector)
{
  for (auto& p : m)
  {
    if ( current_tag_stack == p.second )
    {
      // do something ....
于 2013-10-23T13:28:56.067 回答
1

除了您尝试在地图上访问第二个成员的问题外,我建议您在代码中使用 typedefs。它不仅会简化您的代码,而且会在必要时帮助更改数据结构。在您的情况下,所有这些定义都围绕您的代码:

std::map< int, std::vector<int> >
std::vector< std::map< int, std::vector<int> > >
std::map<int, std::vector<int> > vDescriptorAtom;
std::vector<int> current_tag_stack;

将其与:

typedef std::vector<int> tag_stack;
typedef std::map<int,tag_stack> tag_stack_map;

tag_stack_map vDescriptorAtom;
tag_stack current_tag_stack;

并想象有一天您需要将 tag_stack 从 std::vector 更改为其他内容。哪里会更容易?

于 2013-10-23T14:02:57.463 回答
1

函数 at() 返回对指定位置 pos 的元素的引用,因此您应该编写:

(messageDescriptorVector.at(i)).second

我更喜欢这样写代码:

std::map<int, std::vector<int>> vDescriptorAtom;
std::vector<std::map<int, std::vector<int>>> messageDescriptorVector;

vDescriptorAtom[498] = vListOfIds;
messageDescriptorVector.push_back( vDescriptorAtom );

// do something

for(auto& maps : messageDescriptorVector)
    for(auto& pairs : maps)
        if (current_tag_stack == pairs.second)
            // do something
于 2019-12-05T19:55:42.973 回答