istream的运算符之间的差异>>libc++和libstdc++之间的double&val)

Discrepancy between istream's operator>> (double& val) between libc++ and libstdc++

本文关键字:gt 之间 libstdc++ double val libc++ istream 运算符      更新时间:2023-10-16

随着我最近升级到Mac OS X 10.9,默认的标准C++库从libstdc++更改为libc ++。从那时起,我观察到下面的代码示例中记录的字符串流运算符>>(double)的意外行为。

总之,当双精度值后跟一个字母时,libc++ 似乎在从字符串流中提取双精度值时存在问题。

我已经检查了标准(2003),但我找不到任何具体信息,在这种情况下提取是否应该有效。

因此,如果有任何输入,无论这是libc ++还是libstdc++中的错误,我将不胜感激。

#include <sstream>
#include <iostream>
using namespace std;
void extract_double(const string & s)
{
  stringstream ss;
  double d;
  ss << s;
  ss >> d;
  if(!ss.fail())
    cout << "'" << ss.str() << "' converted to " << d << endl;
  else
    cout << "'" << ss.str() << "' failed to convert to double" << endl;
}
int main()
{
  extract_double("-4.9");
  extract_double("-4.9 X");
  extract_double("-4.9_");
  extract_double("-4.9d");
  extract_double("-4.9X");
}

使用 c++ --stdlib=libc++ streamtest.cxx 编译代码会得到

'-4.9' converted to -4.9
'-4.9 X' converted to -4.9
'-4.9_' converted to -4.9
'-4.9d' failed to convert to double
'-4.9X' failed to convert to double

使用 c++ --stdlib=libstdc++ streamtest.cxx 编译代码会得到

'-4.9' converted to -4.9
'-4.9 X' converted to -4.9
'-4.9_' converted to -4.9
'-4.9d' converted to -4.9
'-4.9X' converted to -4.9

编译器版本为

$ c++ --version
Apple LLVM version 5.0 (clang-500.2.79) (based on LLVM 3.3svn)
Target: x86_64-apple-darwin13.0.0
Thread model: posix

根据(2011)标准的22.4.2.1.2,libstdc++似乎是对的,libc++是错的。

在第 2 阶段,

如果未丢弃 [字符 - n.m.

],则进行检查以确定是否允许 c 作为阶段 1 返回的转换说明符的输入字段的下一个字符 [在本例中为 "%g" - n.m.]。如果是这样,则累积。

由于%g转换说明符不允许dX字符,因此不会累加该字符。它也不会被丢弃(只能丢弃组分隔符)。因此,阶段 2 必须在此时结束。

然后在第 3 阶段转换累积的字符。

看起来libc++错误地在第2阶段累积dX,然后尝试转换它们,但这失败了。