Следующие коды будут аварийно завершаться при компиляции 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-делить на ноль, vptr, функция -fno-sanitize-recovery -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?
Это ошибка в libstdc ++ в соответствии с http://lists.cs.uiuc.edu/pipermail/cfe-dev/2013-January/027401.html.
Все еще присутствует в 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