私は、stdマップで奇妙な動作が発生しているところで作業しています。#pragma packエラーによるメモリ破損 - std map破損 - 挿入時にクラッシュする
カスタムタイプのポインタにマップされた独自のtypedefマップがありました。最初のペアをマップに追加した後、いつでもアプリケーションがクラッシュしました。
多くの混乱の後、マップをaに変更し、アプリケーションの最初の呼び出しに移動しましたが、それでもクラッシュします。私は何が起こっているのか分かりません。どんな助けもありがとう。
現時点ではクラッシュするコードです。
LoggerPtr syslogger(Logger::getLogger("CISInterface"));
int main(int argc, char *argv[])
{
typedef std::map<string, string> MyMapDef;
MyMapDef tmpString;
tmpString.insert(MyMapDef::value_type("0000", "d"));
tmpString.insert(MyMapDef::value_type("1111", "d")); //Crashes here.
tmpString.insert(MyMapDef::value_type("2222", "d"));
// std::string configFile;
// int c;
// if(argc < 2)
// {
// //Must have c option
// std::cout << "Usage -c configFileName" << std::endl;
// exit(EXIT_FAILURE);
// }
//Rest of main commented out.
...
そして、ここでスタックトレースがある - 私はそれを見てしなければならない問題を引き起こしている可能性があり、他にどのような分野
CISInterface Debug [C/C++ Application]
gdb/mi (10/31/12 6:02 PM) (Suspended)
Thread [1] (Suspended: Signal 'SIGSEGV' received. Description: Segmentation fault.)
6 std::basic_string<char, std::char_traits<char>, std::allocator<char> >::compare(std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&) const() 0x00000032fd49c416
5 std::operator< <char, std::char_traits<char>, std::allocator<char> >() basic_string.h:2317 0x0000000000417ec7
4 std::less<std::basic_string<char, std::char_traits<char>, std::allocator<char> > >::operator() stl_function.h:230 0x000000000041706f
3 std::_Rb_tree<std::basic_string<char, std::char_traits<char>, std::allocator<char> >, std::pair<std::basic_string<char, std::char_traits<char>, std::allocator<char> > const, std::basic_string<char, std::char_traits<char>, std::allocator<char> > >, std::_Select1st<std::pair<std::basic_string<char, std::char_traits<char>, std::allocator<char> > const, std::basic_string<char, std::char_traits<char>, std::allocator<char> > > >, std::less<std::basic_string<char, std::char_traits<char>, std::allocator<char> > >, std::allocator<std::pair<std::basic_string<char, std::char_traits<char>, std::allocator<char> > const, std::basic_string<char, std::char_traits<char>, std::allocator<char> > > > >::_M_insert_unique() stl_tree.h:1170 0x0000000000415d00
2 std::map<std::basic_string<char, std::char_traits<char>, std::allocator<char> >, std::basic_string<char, std::char_traits<char>, std::allocator<char> >, std::less<std::basic_string<char, std::char_traits<char>, std::allocator<char> > >, std::allocator<std::pair<std::basic_string<char, std::char_traits<char>, std::allocator<char> > const, std::basic_string<char, std::char_traits<char>, std::allocator<char> > > > >::insert() stl_map.h:500 0x00000000004150eb
1 main() CISInterface.cpp:29 0x000000000041916d
gdb (10/31/12 6:02 PM)
/home/cillian/workspace/CISInterface/Debug/CISInterface (10/31/12 6:02 PM)
。私がリンクしている図書館にはありますか?私は、同じライブラリにリンクするコード行だけで2番目のプロジェクトを作成しましたが(しかし、それらに呼び出すコードはありません)、クラッシュしません。
あなたが投稿しているコードは、すべてのコードが本当にあるならば、**のみ**あなたの問題を引き起こしている可能なことは 'LoggerPtrののsyslogger(ロガー::のgetLogger(「CISInterface」))によって引き起こされるヒープ破損であります;'。 'main'のコードは正しいです。その行をコメントアウトして、まだクラッシュするかどうか確認してください。 – john
私はあなたの 'main()'をコピーしてここで走らせました(Ubuntu 12.04、gcc 4.6.3)。これまでのところ問題ありません。エラーは他の場所にある必要があります。 –
どちらが29行ですか? –