2

そのため、次の URL で boost::unordered_map のドキュメントを読んでいました。

http://www.boost.org/doc/libs/1_52_0/doc/html/boost/unordered_map.html#id1395195-bb

operator[] の効果と戻り値は

効果: コンテナーに k に相当するキーを持つ要素がまだ含まれていない場合、値 std::pair(k, mapped_type()) を挿入します。

戻り値: x.second への参照。ここで、x はコンテナー内に既に存在する要素、または k に相当するキーを持つ新しく挿入された要素です。

次のコードを実行すると、map["xyz"] へのポインターが 0 であることが示されます。多くの人が find(key_value) を使用していますが、これがどのように機能するかはわかりませんでした。

#import <iostream>
#import <boost/unordered_map.hpp>

class myClass
{
public:
    myClass():_i(-1){};
    myClass(int i):_i(i){};
    int _i;
};

int main()
{
    boost::unordered_map<std::string,myClass*> map;
    map["abc"] = new myClass(1);
    std::cout << map["abc"] << std::endl;
    std::cout << map["xyz"] << std::endl;
    return 0;
}
4

1 に答える 1

4

Yakkが提案したように、私の回答を投稿から回答に移動します。

それで、私は自分の問題を解決し、他の人が私の経験から恩恵を受けたり、コメントを持ったりする可能性があることを理解したので、まだ投稿しています.

起こっていたことは、マップに新しい要素を作成していたことだと思います。rhs だけが myClass* でした。これを次のように書き直しました

class myClass
{
public:
    myClass():_i(-1){};
    myClass(int i):_i(i){};
    int _i;

    friend std::ostream& operator<< (std::ostream& stream, const myClass& myClass){return stream << "[" << myClass._i << "]";}
};

int main()
{
    boost::unordered_map<std::string,myClass> map;
    map["abc"] = myClass(1);
    std::cout << map["abc"] << std::endl;
    std::cout << map["xyz"] << std::endl;
    return 0;
}

ここに私の出力があります:

$ g++ test.cpp && ./a.out 
[1]
[-1]

これが困っている人に役立つことを願っています。

于 2013-03-06T15:35:16.593 に答える