函数仅在按Enter或到达文件末尾时才会导致分割故障
Function is causing a segmentation fault only when you press enter or it reaches the end of a file
此函数是一项正在进行的工作,旨在读取简单整数计算器的stdin数据。该函数在输入操作员和两个操作数时按预期工作: 2 2.它还从命令行中的文件中正确读取具有类似格式的文件。尽管如此,如果用户击中命令行上的输入或到达文件的末尾,它将segfualt。我不确定我出了什么问题吗?什么可能导致这种行为?
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();
}
}
如果没有读取字符串,因此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]));
相关文章:
- 分割故障C++矩阵
- C ,二进制树的高度,而不是检查我的子树是否为空,而是在检查我的子树是否是叶子节点.抛出分割故障
- 我正在为此代码分割故障
- 在执行strcpy时获取分割故障错误
- 空隙指针分割故障
- Xcode会产生分割故障,而不是例外
- OPENCV C 中的分割故障误差
- 分割故障:核心倾倒C 矢量对字符串:
- C 2D数组导致分割故障(核心倾倒)
- 分割故障/错误读数变量-C 列表
- DLSYM导致分割故障
- 使用C 中的操作员删除的分割故障
- 使用Linux X64下的Libmozjs-52(SpidermonKey)进行分割故障
- 使用长变量时分割故障(11)错误
- C - 返回字符串时的分割故障
- 创建VertexArray时的分割故障
- 向量分割故障的向量
- 从std :: fileSystem ::路径对象的类中退出时的分割故障
- C 矢量分割故障
- 基于向量的数据格式的分割故障误差