Clang ++ UBSAN报告类型&st; :: _ Ios_Fmtflags'的无效值。

时间:2015-06-29 05:09:07

标签: c++ clang ubsan

以下代码在由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编译:

  

$&GT; clang ++ - 3.6 -fsanitize = undefined -fno-sanitize = float-divide-by-zero,vptr,function -fno-sanitize-recover -o test test.cpp

然后程序崩溃了:

  

$&GT; 。/测试   在floatToString中   /usr/bin/../lib/gcc/x86_64-linux-gnu/4.8/../../../../include/c++/4.8/bits/ios_base.h:96:24:运行时错误:加载值4294966271,这不是类型&#39; std :: _ Ios_Fmtflags&#39;

的有效值

当我打开clang UBSAN时,有人能帮助解决这个问题的原因吗?

1 个答案:

答案 0 :(得分:1)

根据http://lists.cs.uiuc.edu/pipermail/cfe-dev/2013-January/027401.html,这是libstdc ++中的一个错误。

仍存在于libstdc ++ 5.1中。

libc ++按预期工作:

$ clang++ -stdlib=libc++ -fsanitize=undefined -fno-sanitize=float-divide-by-zero,vptr,function -fno-sanitize-recover -o test test.cpp -lc++abi

$ ./test
in floatToString
exit floatToString
1