- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在读取包含以下行的文本文件:
deltaT 0.005;
在字符串中找到正确的行后,我想使用如下代码读出该值:
double deltaT;
stringstream ss(line);
ss >> tag; //Contains: deltaT
ss >> deltaT; //Should contain: 0.005
在调试过程中,我看到 deltaT 包含:0.0050000000000000001
那么有没有办法像流插入器一样设置提取器的“精度”?
或者保证文本文件中的值是我程序中的 double 值的最佳方法是什么。
谢谢,玛德琳。
1 Câu trả lời
这是二进制浮点类型的常见问题:0.005
不能完全用 gấp đôi
表示,因此从“十进制字面值”进行的转换会产生最相似的结果由 gấp đôi
表示的数字。
如果您想使用gấp đôi
或其他有限的二进制浮点类型,则没有解决方案,因为0.005
具有十进制的有限形式,但是is periodic in binary (并且任何 FP 类型的尾数都是有限的)。
要了解这怎么可能,请考虑分数 1/3:在基数 3 中它具有有限表示,而在基数 10 中它是周期性的:
(1/3)10 = 0.33333...10 = 0.13
现在,任何“常规”浮点类型都只有一些有限的尾数空间(即要存储的有效数字),因此每个周期数都必须在某个点被截断(实际上是四舍五入);这会导致您看到的精度下降。
请注意,有几个“任意精度库”可用于处理此类问题并以仅受可用内存限制的精度进行数学计算(例如 GMP ),但您应该考虑额外的复杂性/性能损失精度的提高实际上是合理的。
另一种解决方案(通常在进行涉及金钱的计算时使用)是使用固定精度类型,它将金额存储为整数,并按某个小数因子“隐式缩放”(概念是将美分存储为整数而不是美元作为 trôi nổi
或其他);这避免了从十进制到二进制转换的任何意外,因为所有整数都可以用任何基数中有限的数字精确表示。
关于C++ istream 提取器精度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13388425/
我正在尝试弄清楚如何让一个成员变量代表传入的 istream 或类自己创建的成员变量。 我认为,如果我动态分配类创建的 istream,那么使用指向 istream 的指针可能会起作用;然而,问题在于
我正在尝试理解这段代码 istream &read(istream &is, Sales_data &item) { double price = 0; is >> item.b
我编写了一个实现 IStream(COM 接口(interface)而不是 C++ 标准库类)的过滤器。这一切都很好,但我的问题是我不确定何时(如果有的话)我可以确定不会发送进一步的 IStream
我正在测试 C++PL 书中的一段代码并找到了下一段代码(我不想感觉我是在将它从书中复制粘贴到我的 IDE,所以我至少改变了变量名): istream& operator>> (istream& is
我正在阅读 C++ Practical Programming by Example by Andrew Koenig (Author)并在 4.1.3 Reading homework grades
我正在尝试使用 istream& getline 而不是使用 istream& operator 从文件中读取行。 结果cpp #include "Result.h" Result::Result()
我试图通过套接字连接发送图像,但我遇到了以下代码的问题: //stream to char array STATSTG myStreamStats; ULONG bytesSaved; myStrea
这里有两段代码,我起初认为它们应该是等价的: { std::ifstream stream("test.bin", std::ios_base::in | std::ios_base::bin
我在网上查了,但没找到合适的。 怎么可能有这样的主线(原始主线): int main() { Image left; std::ifstream ifs("l
假设我有以下代码: std::ifstream file(name, flags); file.seekg(0, std::ios::beg); // Check for error file.rea
在 Windows 上的 C++ 中,是否有任何简单的方法可以为现有 std::stream 对象创建 (COM) IStream 接口(interface)? 一个示例是使用 IWICStream:
考虑以下简单程序,它将输入拆分为空白并每行打印出一个非空白标记: #include int main(int argc, char* argv[]) { while (std::ci
istream& getline (istream& is, string& str); 此处 str 在换行符后终止。但是,如果我想处理 str cotents 2-3 行的情况,那么还有什么选择呢
这个问题已经有答案了: Java multiple file transfer over socket (3 个回答) 已关闭 5 年前。 我正在编写一个程序在两台计算机之间传输文件,但我没有关闭套接
void transferData(ifstream& input_file, ofstream& output_file) { char ch; while (input_file
我正在读取包含以下行的文本文件: deltaT 0.005; 在字符串中找到正确的行后,我想使用如下代码读出该值: double deltaT;
我正在查看 istream 类,但没有看到可以完全清除缓冲区并将输入设置为为下一个“干净”输入做好准备的方法。 我为我的类定义了提取运算符,在我的主程序中我要求用户输入,如下所示: while (tr
我正在编写一个解析器,之前我在尝试解析标识符(任何对 C++ 变量名有效的东西)和未闭合的字符串文字(任何以 " 开头的东西)时遇到了麻烦,但是在我的输入末尾缺少结束符 ")。我认为这是因为词法分析器
我得到了一个具有以下签名的函数。我无法改变它,我必须接受它。 void parse(std::istream & in); 我应该测试这个函数,所以基本上用预定义的内容调用它并检查值是否被正确解析。因
我的运算符(operator)有问题>> istream& operator>> (istream& is, Matrix& M) { char first; is>>first;
Tôi là một lập trình viên xuất sắc, rất giỏi!