【发布时间】:2015-09-15 11:20:54
【问题描述】:
clang UBSAN编译以下代码会崩溃
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <sstream>
template<class T>
inline std::string floatToString(T i){
printf("in floatToString\n");
std::stringstream ss;
ss.precision(6);
ss << std::noshowpoint << i;
printf("exit floatToString\n");
return ss.str();
}
int main() {
std::cout << floatToString(1.0) << "\n";
return 0;
}
使用 Clang 3.6 编译:
$> clang++-3.6 -fsanitize=undefined -fno-sanitize=float-divide-by-zero,vptr,function -fno-sanitize-recover -o test test.cpp
然后程序崩溃了:
$> ./test 在 floatToString /usr/bin/../lib/gcc/x86_64-linux-gnu/4.8/../../../../include/c++/4.8/bits/ios_base.h:96:24:运行时错误: 值 4294966271 的负载,这不是类型“std::_Ios_Fmtflags”的有效值
有人可以帮助我打开 clang UBSAN 时为什么会出现这个问题吗?
【问题讨论】: