SIGNAL SEGV (segmentation fault) out of vector push_back 方法
SIGNALSEGV (segmentation fault) out of vector pushback method
我正在使用 linux (WSL) 制作 shell。
出于某种未知原因,当我将一个结构指针(我创建的)推回一个向量时,它调用 SIGNALSEGV。
这些是主要的类有问题的代码,
class TimeoutCommand : public BuiltInCommand {
public:
bool background;
std::string line;
int pid;
int duration;
TimeoutCommand(const char* cmd_line); //prepare line
virtual ~TimeoutCommand() {}
void execute() override; ////set alarm + fork + add to joblist + add to timelist
};
class TimeoutList{
public:
struct TimeoutEntry {
std::string line;
int pid;
time_t start_time;
int duration;
TimeoutEntry(int pid,time_t start_time,std::string line,int duration)
:pid(pid),start_time(start_time),line(line),duration(duration)
{};
};
std::vector<TimeoutEntry*> TimeoutVec;
TimeoutList();
~TimeoutList() {
for (TimeoutEntry *entry : TimeoutVec)
delete entry;
}
void addCommand(TimeoutCommand* cmd); ////add new timeout
void timeoutCheck(); ////timout timedoutcommands
};
这是 TimeoutCommand 构造函数和调用有问题函数的行:
TimeoutCommand::TimeoutCommand(const char *cmd_line)
:BuiltInCommand(cmd_line)
{
_parseCommandLine(cmd_line,args);
background=_isBackgroundComamnd(cmd_line);
for(int i=2;args[i]!=NULL;i++) {
line +=args[i];
}
duration=stoi(args[1]);
}
void TimeoutCommand::execute() {
alarm(duration);
**SmallShell::getInstance().timouts->addCommand(this);**
...
...
...
最后是有问题的功能:
void TimeoutList::addCommand(TimeoutCommand *cmd) {
time_t t= time(NULL);
if (t==-1){
perror("smash error: time failed");
return;
}
TimeoutEntry* entry = new TimeoutEntry(cmd->pid,t,cmd->line,cmd->duration);
**TimeoutVec.push_back(entry);**
}
什么导致分段错误?
我没有立即看到任何奇怪的指针混乱或类似的东西。
运行 这个命令看起来像这样:
超时 3 睡眠 10
这将是 cmd_line
这是 std::vector 中导致段错误的部分
push_back(const value_type& __x)
{
**if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage)**
{
_GLIBCXX_ASAN_ANNOTATE_GROW(1);
_Alloc_traits::construct(this->_M_impl, this->_M_impl._M_finish,
__x);
++this->_M_impl._M_finish;
_GLIBCXX_ASAN_ANNOTATE_GREW(1);
}
else
_M_realloc_insert(end(), __x);
}
**有问题的行标有** **
问题是我在没有分配新实例的情况下安装了指向 TimeoutList 实例的指针。
我正在使用 linux (WSL) 制作 shell。 出于某种未知原因,当我将一个结构指针(我创建的)推回一个向量时,它调用 SIGNALSEGV。
这些是主要的类有问题的代码,
class TimeoutCommand : public BuiltInCommand {
public:
bool background;
std::string line;
int pid;
int duration;
TimeoutCommand(const char* cmd_line); //prepare line
virtual ~TimeoutCommand() {}
void execute() override; ////set alarm + fork + add to joblist + add to timelist
};
class TimeoutList{
public:
struct TimeoutEntry {
std::string line;
int pid;
time_t start_time;
int duration;
TimeoutEntry(int pid,time_t start_time,std::string line,int duration)
:pid(pid),start_time(start_time),line(line),duration(duration)
{};
};
std::vector<TimeoutEntry*> TimeoutVec;
TimeoutList();
~TimeoutList() {
for (TimeoutEntry *entry : TimeoutVec)
delete entry;
}
void addCommand(TimeoutCommand* cmd); ////add new timeout
void timeoutCheck(); ////timout timedoutcommands
};
这是 TimeoutCommand 构造函数和调用有问题函数的行:
TimeoutCommand::TimeoutCommand(const char *cmd_line)
:BuiltInCommand(cmd_line)
{
_parseCommandLine(cmd_line,args);
background=_isBackgroundComamnd(cmd_line);
for(int i=2;args[i]!=NULL;i++) {
line +=args[i];
}
duration=stoi(args[1]);
}
void TimeoutCommand::execute() {
alarm(duration);
**SmallShell::getInstance().timouts->addCommand(this);**
...
...
...
最后是有问题的功能:
void TimeoutList::addCommand(TimeoutCommand *cmd) {
time_t t= time(NULL);
if (t==-1){
perror("smash error: time failed");
return;
}
TimeoutEntry* entry = new TimeoutEntry(cmd->pid,t,cmd->line,cmd->duration);
**TimeoutVec.push_back(entry);**
}
什么导致分段错误? 我没有立即看到任何奇怪的指针混乱或类似的东西。
运行 这个命令看起来像这样: 超时 3 睡眠 10
这将是 cmd_line
这是 std::vector 中导致段错误的部分
push_back(const value_type& __x)
{
**if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage)**
{
_GLIBCXX_ASAN_ANNOTATE_GROW(1);
_Alloc_traits::construct(this->_M_impl, this->_M_impl._M_finish,
__x);
++this->_M_impl._M_finish;
_GLIBCXX_ASAN_ANNOTATE_GREW(1);
}
else
_M_realloc_insert(end(), __x);
}
**有问题的行标有** **
问题是我在没有分配新实例的情况下安装了指向 TimeoutList 实例的指针。