1

C++ でマップ構造のマップをセットアップしようとしていますが、期待どおりに動作させることができません。この問題を説明するために、このサンプル プログラムをまとめました。複雑に見える場合はご容赦ください。ケースはできる限り保存したいと思います。

したがって、現在の出力は次のとおりです。L1, size = 0 私が期待していたのは次のようなものです。

L1, size 1
   L2, 4

2 番目のレベルのマップが適切に確立されていないようです。おそらくスコーピングの問題ですが、よくわかりません。プログラムは以下の通りです。

// So the map is
// AKEY -> { BKEY -> [ SegPair, SegPair  .... ] }

#include <map>
#include <utility>
#include <iostream>
#include <vector>

typedef std::string AKEY;
typedef std::string BKEY;

typedef std::pair<int,int> SegPair;
typedef std::vector<SegPair> SegVec;
typedef std::map<BKEY, SegVec> Ensemble;
typedef std::map<AKEY, Ensemble> Oracle;

using std::string;

Oracle o = Oracle();

void setup(string akey, string bkey, int x, int y) {
    auto pos = o.find(akey);
    if (pos == o.end()) {
        o[akey] = Ensemble();
    }

    Ensemble e = o[akey];

    auto pos2 = e.find(bkey);
    if (pos2 == e.end()) {
        e[bkey] = SegVec();
    }

    SegPair p(x, y);
    e[bkey].push_back(p);
}

int main(void) {

    setup("L1", "L2", 3, 4);

    for (auto it = o.begin(); it != o.end(); it++) {
        std::cout << it->first;
        Ensemble e = it->second;
        std::cout << ", size = " << e.size() << "\n";
        for (auto it2 = e.begin(); it2 != e.end(); it2++) {
            std::cout << "\t" << it2-> first << "\n";
            SegVec v = it2->second;
            for (int i = 0; i < v.size(); i++)
                std::cout<< v[i].second << " ";
        }
    }
}
4

2 に答える 2

2

あなたの問題はこの行にあると思います:

Ensemble e = o[akey];

突然変異のために、参照によってマップの左辺値をキャプチャするのではなく、ローカルを作成しています。したがって、その時点以降に e に加えた変更は、e が範囲外になると単純に破棄されます。

于 2013-04-26T14:40:39.763 に答える
1

setup、のオブジェクトeコピーoです。
あなたがそれを変更するとき、あなたは何も変更していませんo

修正するには、参照を使用します:

Ensemble& e = o[akey];

これにより、コピーの代わりにe同じものを参照できます。o[akey]

于 2013-04-26T14:44:05.750 に答える