这段c++代码有什么问题?
whats wrong with this c++ piece of code?
在这段代码中,在while循环的每次迭代中,从文件中读取一行。该行类似于:
13, 4636137, 29464742, 29464746, 995560164
对于以粗体指定的每个数字,在for循环中检查该数字是否作为std::map中的键。如果键存在,则将值附加到字符串。然后将字符串写入文件。
如果映射中不存在其中一个键,则不应将该行写入文件。(bool is_points_in_range)
但在实践中,如果最后一个点(在for循环之外)不在键列表中,程序逻辑执行得很好。
为什么在for循环中布尔运算符不改变?
vector<string> res;
ifstream infile;
map<string, string> m;
while(infile.getline(buffer, LINE_BUFFER_LEN))
{
line=string(buffer);
res = SplitBySep(line, ",");
bool is_points_in_range=true;
string geo_file_line;
for (int i=2;i<res.size()-1;i++){
if ( m.find(res[i]) == m.end() ) {
is_points_in_range=false;
break;
} else {
geo_file_line= geo_file_line.append(m[res[i]]).append("^");
}
}
if ( m.find(res[res.size()-1]) == m.end() ) {
is_points_in_range=false;
} else {
geo_file_line= geo_file_line.append(m[res[res.size()-1]]).append("n");
}
if (is_points_in_range){
fprintf(fp_geo, "%s",geo_file_line.c_str());
}
}
res.size()-1
极其危险。res.size()
是无符号类型,当res.size()
为0时,从它减去1将得到一个非常大的无符号整数,因为环绕。
因此,当res
未填充时,您的程序本质上是未定义的。
我很惊讶你的编译器没有警告你。你把警告关掉了吗?
看起来m.find(res[i]) == m.end()
从来都不是真的。你确定这张桌子已经坐满了吗?res[i]
最好问一下为什么这个条件语句不能很好地工作?我们知道,要获取std::map中存在的键,可以使用:
if ( m.find("f") == m.end() ) {
// not found
} else {
// found
}
如问题所示但
map<string, string> m;
这个语句不能很好地工作。我没有任何29464742键(我确定),但是当我搜索这个键时,else部分被执行。同样,当我使用m.count('29464742')时,返回1。我不知道为什么?
我用这个条件语句纠正了我的代码:
if ( m["f"] == "" ) {
// not found
} else {
// found
}
相关文章:
- 警告处理为错误这里有什么问题
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 当我尝试添加 2 个大字符串时,我无法弄清楚出了什么问题
- 违反const正确性:我应该现实地期待什么问题
- 这个带有模板<类 Vector 的C++代码片段有什么问题>
- 我的逻辑反转字符串中的元音有什么问题?
- 需要以下代码的帮助,下面的代码有什么问题
- 常量公共成员有什么问题?
- c++无值sort()的问题是什么?
- 以下代码中的函数模板有什么问题?
- 这个返回元素位置的基于循环的函数有什么问题?
- creat_list2功能有什么问题?
- 基本的 c++ 问题:如果我在函数中创建某些内容并返回它会发生什么?
- 我遇到了黑客排名中的问题"TWO STRINGS"的三个测试用例的分段错误。原因是什么?
- 什么是钻石问题?是一系列问题还是特定问题?
- 格式说明符C++有什么问题
- 我应该在 main 函数中写什么来测试我的问题?
- 任何人都可以告诉我我的 C++ 代码出了什么问题?
- 方法问题 - 什么会改变值,什么不会改变?什么是无效的?