微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c – 为什么sprintf_s在不同版本的Visual Studio中给出不同的结果?

sprintf_s(buf,"%.*f",14,0.182696884245135);

在VS2008 = 0.18269688424514

在VS2015 = 0.18269688424513

sprintf_s的行为是否改变了?我怎样才能得到旧的行为?

解决方法

我们为 the Universal CRT和Visual C 2015重写了浮点解析器和格式化程序,以提高正确性.请参阅Visual C 2015的 Breaking Changes in Visual C++文档;有一节题为“浮点格式化和解析”.

Visual C 2015结果是正确的舍入结果.输入字符串0.182696884245135将转换为以下双精度值,这是最接近的可表示值:

0.18269688424513'49994693288181224488653242588043212890625

请注意第14个小数位后的刻度线.第15位是4,所以在用14位小数位格式化数字时,数字是“向下舍入”(或截断),而不是向上.

Visual C 2008结果不正确.我不知道在解析或格式化过程中是否引入了错误.使用Universal CRT和Visual C 2015无法获得旧的,不正确的行为.

原文地址:https://www.jb51.cc/c/111498.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐