Функция вызывает ошибку сегментации, только когда вы нажимаете клавишу ввода или она достигает конца файла
Эта функция находится в стадии разработки и предназначена для чтения данных из стандартного стандартного калькулятора. Функция работает, как и предполагалось, при вводе оператора и двух операндов: + 2 2. Она также правильно считывает данные из файла с аналогичным форматированием, введенным в командной строке. Несмотря на это, он будет работать, если пользователь нажмет ввод в командной строке или достигнет конца файла. Я не уверен, где я ошибся? Что может быть причиной такого поведения?
void process_input ()
{
while(!std::cin.eof())
{
std::string line;
std::string n;
getline(std::cin, line);
if (std::cin.fail())
break;
else if (line == "quit")
return;
std::istringstream stream(line);
std::vector<std::string> input_cpy(0);
while (stream >> n)
input_cpy.push_back(n);
//Clear global_input_cpy on each iteration and load the new line into it
global_input_cpy.clear();
for (int i = 0; i < input_cpy.size(); ++i)
global_input_cpy.push_back(input_cpy[i]);
if(input_cpy[0] == "+")
sum(std::stol(input_cpy[1]), std::stol(input_cpy[2]));
else if (input_cpy[0] == "*")
multiply(std::stol(input_cpy[1]), std::stol(input_cpy[2]));
else if (input_cpy[0] == "^")
exponent(std::stol(input_cpy[1]), std::stol(input_cpy[2]));
else
std::cout << "input '" << input_cpy[0] << "'" << " unrecognized. skipping." << "\n";
input_cpy.clear();
}
}
1 ответ
Решение
Если строки не читаются и, следовательно, input_cpy
пусто, вы все еще пытаетесь получить доступ input_cpy[0]
и это приводит к неопределенному поведению.
Вам нужно где-то утверждение, что input_cpy.size() >= 2
чтобы эти операторы имели определенное поведение:
if(input_cpy[0] == "+")
sum(std::stol(input_cpy[1]), std::stol(input_cpy[2]));
else if (input_cpy[0] == "*")
multiply(std::stol(input_cpy[1]), std::stol(input_cpy[2]));
else if (input_cpy[0] == "^")
exponent(std::stol(input_cpy[1]), std::stol(input_cpy[2]));