3

私は複数のクラスを持つかなり長いプログラムを持っているので、あなたがそれを必要としない限りそれを投稿しません。しかし、メインリターンの後、セグメンテーション違反が発生します。

GDBを使用すると、次のエラーが表示されます。

program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_INVALID_ADDRESS at address: 0x0000002300103be8
0x00000001000035cc in std::_Rb_tree<std::string, std::string, std::_Identity, std::less,     std::allocator >::_S_right (__x=0x2300103bd0) at stl_tree.h:512
512       { return static_cast<_Link_type>(__x->_M_right); }

私はC++に非常に慣れていないので、これは私にはぎこちないように見えます。誰かがそれを解読できますか?STLコンテナの1つが問題を引き起こしているようです。それを修正する方法について何かアドバイスはありますか?

コードで編集:

さて、私はそれをこのifブロックのどこかに分離しましたmain。それは私が書いた最後のことであり、コメントアウトするとプログラムは正常に実行されます。

else if(line.substr(0, 3) == "Rec") // Recieve 
  {       
      istringstream ss(line);
      string s; // output string
      string upc;
      string name;
      int amount;
      int count = 0;
      while(ss >> s) // go through the words in the line
      {
          count++;
          if(count == 2)
            upc = s;
          else if (count == 3)
          {
            istringstream isa(line.substr(20, 2));
            isa >> amount; //Parse the amount
          }
          else if (count == 4)
            name = s;
      }


      warehouses.find(name)->second.receive_food(upc, amount); //add the food to the warehouse

  }

私たちが見ていることを明確にするために、line次の形式になっています。

Receive: 0984523912 7 Tacoma

warehouses地図です:map<string, a4::warehouse> warehouses; //all the warehouses.

これが倉庫の受け取り方法です

void warehouse::receive_food(std::string upc, int amount)
{
    items.find(upc)->second.receive(amount);

    todays_transactions = todays_transactions + amount;
}

どこitemsにありますかstd::map<std::string, food> items;

そして最後に、フードレシーブメソッド

void food::receive(int amount)
{
    crates.push_back(crate(life, amount));
}

どこcratesにありますかstd::list<crate> crates;

そしてcrate

    class crate
{
    public:
        crate(int, int);
        ~crate();
        int life;
        int quantity;
};
4

1 に答える 1

1

メモリ破損のようです。は、エラーが通常赤黒ツリー_Rb_treeとして実装されているものと関係があることを示唆しています。コードを見ずにこれ以上言うのは難しいです。Valgrindを使用して問題をデバッグすることをお勧めします。std::map

あなたがアップデートに投稿したコードを見た後、問題はwarehouses.find(name)有効な反復子を返すかどうかをチェックしていないことだと思います。map::end()キーが見つからない場合は戻ることができます。

チェックを追加します。

  map<string, a4::warehouse>::iterator it = warehouses.find(name);
  if (it != warehouses.end())
    it->second.receive_food(upc, amount);
  else ; // handle the case of a missing key

への他の呼び出しも同様にチェックしますmap::find

于 2013-02-01T20:51:14.530 に答える