- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
像“为什么不是 0.1+0.1+0.1+0.1+0.1+0.1+0.1+0.1 = 0.8?”这样的问题让我想到了......
... 让编译器警告它四舍五入到二进制浮点类型中最接近的可表示的浮点常量可能会很好(例如 0.1 和 0.8 在 radix-2 float 中四舍五入,否则他们将需要无限量的空间来存储无限数量的数字)。
我查看了 gcc 警告,到目前为止没有找到用于此目的的警告(-Wall
、-Wextra
、-Wfloat-equal
、-Wconversion
、-Wcoercion
(不支持或仅限 C?)、-Wtraditional
(仅限 C)似乎没有做我想做的事情想要)。
我也没有在 Microsoft Visual C++ 编译器中发现这样的警告。
我是否缺少隐藏或很少使用的选项?
有没有编译器有这种警告?
编辑:此警告可用于教育目的,并可作为对浮点新手的提醒。
最佳答案
编译器没有发出此类警告的技术原因。然而,它们只对学生(他们应该在开始认真地使用浮点运算之前学习浮点运算的工作原理)和精通浮点运算的人有用。不幸的是,大多数浮点运算都很粗糙。人们在不关心计算机如何工作的情况下向计算机输入数字,他们接受他们得到的任何结果。
警告必须默认关闭以支持大量现有浮点代码。如果它可用,我会为我在 Mac OS X 数学库中的代码打开它。当然,库中的某些点我们依赖于浮点值的每一位,例如我们使用扩展精度算术的地方,并且值由多个浮点对象表示(例如,我们将有一个具有 1/π 高位的对象,具有 1/π 的另一个对象减去第一个对象,以及具有 1/π 的第三个对象减去前两个对象,给我们大约 150 位的 1/π)。一些这样的值在源文本中以十六进制 float 表示,以避免十进制数字的编译器转换出现任何问题,我们可以轻松转换任何剩余的数字以避免新的编译器警告。
但是,我怀疑我们能否说服编译器开发人员相信有足够多的人会使用此警告,或者它会捕获足够多的错误以值得他们花时间。考虑 libm 的情况。假设我们通常为所有常量写出精确的数字,但有一次写了一些其他数字。这个警告会捕获错误吗?那么,那里有什么错误?最有可能的是,数字被转换为我们想要的值。在打开此警告的情况下编写代码时,我们可能会考虑浮点计算将如何执行,而我们编写的值是否适合我们的目的。例如,它可能是我们计算的某个 minimax 多项式的系数,并且该系数与它要得到的一样好,无论是近似十进制表示还是转换为一些可精确表示的十六进制 float 。
因此,此警告很少会捕获错误。也许它会捕捉到我们输入错误数字的情况,不小心将额外的数字插入十六进制 float 字,导致它超出可表示的有效数字。但那是很少见的。在大多数情况下,我们使用的数字要么简单又简短,要么是从计算它们的软件中复制和粘贴的。在某些情况下,我们会手写特殊值,例如 0x1.fffffffffffffp0。当一个额外的“f”滑入该数字时发出警告可能会在编译期间发现错误,但几乎肯定会在测试中很快发现该错误,因为它会极大地改变特殊值。
因此,这样的编译器警告没有什么用处:很少有人会使用它,而且对于使用它的人来说,它也不会发现很少的错误。
关于c++ - 警告不精确的浮点常量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12619368/
我试图为此搜索答案,但我发现很难找到这种“确切”的例子。我对指向指针的指针知之甚少,我觉得除了指向某物的指针之外,还有更多东西隐藏在它的表层之下。 那么你们会如何翻译呢? void free(sham
我有一个类的属性,比如const CFoo &bar() const,这是什么意思? 最佳答案 bar 方法返回对 const CFoo 的引用(即 bar 之前的 const CFoo & 部分),
例如是 int const x = 3; 有效代码? 如果是的话,意思是一样的 const int x = 3; ? 最佳答案 它们都是有效的代码并且它们都是等价的。对于指针类型,尽管它们都是有效代码
我知道 f(const T& obj) // (1) g(T const& obj) // (2) 是一样的。(我们不能改变f和g中obj的值)。 但是什么 h(T & const) // (3) 真
本节讲解的内容 include和include_once require和require_once 常量 引入文件和常量结合案列 变量操作函数 输出语句 前言 在上篇文章中,我们讨论了函数的应用,但是
我们知道我们可以保护变量的值,因此用户无法更改现有变量的值!这对对象来说没有什么问题吗?? 例如.. const x = 5; x = 10; alert(x) // will be returned
我正准备为 CUDA 设备编写直方图内核。它基于 NVIDIA's paper . 这个想法是每个线程计算某个部分(在我的例子中是体积)的部分直方图并将其写入共享内存块。然而,我遇到了一个奇怪的算法问
常量是固定值,程序执行期间不会改变。常量可以是任何基本数据类型,比如整数常量、浮点常量、字符常量或者字符串常量,还有枚举常量。 常量可以被当作常规的变量,只是它们的值在定义后不能被修改。 整数常
在这种情况下,如何识别是否有变量或字面量传递给函数 f()? 如何实现passed_as_constant()检查(见下面代码)? sub f { my $refStr=\$_[0]; ret
我目前想知道如何在 python 中列出 win32com 中的常量, 例如使用 excel win32com.client.Dispatch('Excel.Application') 有没有办法使用
这个问题在这里已经有了答案: PHP | define() vs. const (9 个回答) 关闭8年前。 在 PHP 中遇到常量问题想知道是否有人可以解释: 这行得通 const _ROOT =
我正在学习 Rust,到目前为止,似乎有 3 种声明变量的方法: const A: u8 = 42; static A: u8 = 42; let A: u8 = 42; 我知道你不能有一个可变的 c
我正在使用函数模板 void _createAttr(T)(args..., in T[]) 并使用 测试 T 的类型函数中的 static if(is(T == char)) 。当我打电话时, _c
这可能是一个天真的问题,我怀疑答案是"is",但我没有运气在这里和其他地方搜索“erlang编译器优化常量”等术语。无论如何,erlang 编译器是否可以(将)在编译时创建一个常量或文字的数据结构,并
我刚遇到这段 Java 脚本代码: const { myKey, uname, issorted, title, hClick, } = this.props; 请告诉我这是什么意
我正在努力实现以下目标: 我有一个父类,有一些逻辑。在子类中,我“重新定义”常量/属性。有没有办法让子属性可以通过父类中定义的方法访问?或者更具体地说 - 有什么方法可以强制“out”方法在下面的示例
如果这是个愚蠢的问题,请原谅。 我有一个带有内部类接口(interface)的“fragment ”外部类。该接口(interface)仅由另一个 Activity 类使用“implements Ou
我是 python 新手,尝试使用默认值并为类实例自定义它们。 因此,在这个示例中,我定义了一个 DEFAULT_STRING 和一个 DEFAULT_SETTINGS 变量,可以使用 customi
在 integer.xml 中,其形式为 0x001 0x002 是代码和 xml 文件都需要的存储常量。 C# 识别 Droid.Resource.Integer.foo,但它有一些大的
是否有跨平台(即跨 Linux、BSD 和 OS X,最好是所有 POSIX)我可以纯粹基于字符串 以编程方式访问诸如 O_RDWR 之类的常量>“O_RDWR”?我正在编写一些(非 C)代码,这些代
我是一名优秀的程序员,十分优秀!