我有一個錯誤與分配,而我得到了賽格故障,在讀核心轉儲時給出了這樣的:賽格故障,需要幫助閱讀核心轉儲
#0 0xb781eb27 in std::basic_string<char, std::char_traits<char>, std::allocator<char> >::size() const() from /usr/lib/libstdc++.so.6
這是代碼片段我相信它是指。
bool flightmap::GetNextCity(int& index, int& nextCity){
bool success = false;
flightRec tmp, tmp2;
for (int i = nextCity; (!success) && (i < size); i++)
{//if Citytmp goes over size, we never found it
tmp.DestinationCity = GetCityName(i);
tmp2 = map[index].Retrieve(tmp,success);
}//end for loop
if (success)
{
nextCity = GetCityNumber(tmp2.DestinationCity);
}//end if
return success;
}
下面是檢索功能:
flightRec sortedListClass::Retrieve(flightRec& input, bool& success) const{
nodeptr curr;
flightRec tmp;
curr = head;
if (head == NULL)
{//If the list is empty
std::cout << "List empty, operation not preformed" << std::endl;
success = false;
}
/*LINE 167*/ while ((curr!=NULL)&&(!(curr->DestinationCity==input.DestinationCity))) //<- THIS IS LINE 167
{//Here we first check if curr points to NULL, then we see if DesinationCity and Origin are not yet found.
curr=curr->ptr;
}
if ((curr->DestinationCity==input.DestinationCity))
{//If we found it, then let's return it...
tmp.DestinationCity=curr->DestinationCity;
//tmp.Origin=curr->Origin;
tmp.flightnumber=curr->flightnumber;
tmp.cost=curr->cost;
success = true;
return tmp;
}
else //We didn't and then...damn.
{
//std::cout << "Can't find flight to " << input.DestinationCity << std::endl;
success = false;
}
}
flightRec:
struct flightRec{
std::string Origin;
int flightnumber;
float cost;
std::string DestinationCity;
bool operator <(const flightRec& rhs) const;
bool operator ==(const flightRec& rhs) const;
flightRec* ptr;
};
typedef flightRec* nodeptr;
flightMap.h
#ifndef FLIGHTMAP_H
#define FLIGHTMAP_H
#include "sortedListClass.h"
#include "stackClass.h"
#include <fstream>
#include <cstdio>
class flightmap {
public:
flightmap();
flightmap(const flightmap& orig);
virtual ~flightmap();
void readcities (std::ifstream& in);
void readflights (std::ifstream& in);
void display();
void isPath (int& in, int& out);
void MarkVisited (int& index);
bool IsVisited (int& index);
void UnvisitAll();
bool GetNextCity (int& index, int& nextCity);
int GetCityNumber(std::string& city);
std::string GetCityName(int& index);
private:
int size;
sortedListClass* map;
std::string* origin;
bool* visited;
};
#endif
打字BT到GDB在這之後是輸出是什麼:
#0 0xb7f4eb27 in std::basic_string<char, std::char_traits<char>, std::allocator<char> >::size() const() from /usr/lib/libstdc++.so.6
#1 0x0804a407 in std::operator==<char> (__lhs=..., __rhs=...) at /usr/lib/gcc/i686-pc-linux-gnu/4.5.2/../../../../include/c++/4.5.2/bits/basic_string.h:2345
#2 0x0804ab32 in sortedListClass::Retrieve (this=0x8053468, input=..., [email protected]) at sortedListClass.cpp:167
#3 0x0804a1ff in flightmap::GetNextCity (this=0xbffff4dc, [email protected], [email protected]) at flightMap.cpp:197
#4 0x08049ba7 in flightmap::isPath (this=0xbffff4dc, [email protected], [email protected]) at flightMap.cpp:110
#5 0x08049314 in FindPath (datafile=..., map=...) at ola6.cpp:51
#6 0x08049190 in main (argc=2, argv=0xbffff5b4) at ola6.cpp:35
您必須發佈完整的回溯。 #0只會告訴你問題被觸發的功能,但它不會告訴你它是如何到達那裏的。你需要關注它,直到你到達源代碼文件中的一行,這會告訴你代碼中的哪一行會導致問題。我不認爲這可能是您發佈的代碼段。 – Malvineous 2011-04-17 04:49:30
我不知道如何在gdb中做到這一點。 – Athetius 2011-04-17 04:50:40