- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
如果您反射(reflection) WindowsBase.dll > MS.Internal.DoubleUtil.AreClose(...)
,您将获得以下代码:
public static bool AreClose(double value1, double value2)
{
if (value1 == value2)
{
return true;
}
double num2 = ((Math.Abs(value1) + Math.Abs(value2)) + 10.0) * 2.2204460492503131E-16;
double num = value1 - value2;
return ((-num2 < num) && (num2 > num));
}
我试图理解两件不同的事情:
他们从哪里得出 num2 的公式?我想我只是不明白首先将 10.0
的值相加,然后将所有结果乘以这个数字 2.2204460492503131E-16
的意义。有人知道为什么使用这个公式吗?
那里的 return 语句有什么意义?似乎默认情况下如果 num2 大于 num 而不是 num2 的取反值应该小于 num。也许我在这里遗漏了一些东西,但这似乎是多余的。对我来说,这就像检查 5 是否大于 3 以及 -5 是否小于 3(作为示例)。
最佳答案
这似乎是一个基于所比较数字大小的“容差”值。请注意,由于 float 的表示方式,指数为 0 的数字之间的最小可表示差为 2-53 或大约 1.11022 × 10-16。 (请参阅维基百科上的 unit in the last place 和 floating point。)此处的常量恰好是该值的两倍,因此它允许计算过程中累积的小舍入误差。
如果您重新排列条件中的参数,然后将 num2
重命名为 tolerance
并将 num
重命名为 diff
,它应该变得清晰。
即:
return ((-num2 < num) && (num2 > num));
return ((num > -num2) && (num < num2));
return ((diff > -tolerance) && (diff < tolerance));
关于c# - 我试图理解我反射(reflect)过的微软的 DoubleUtil.AreClose() 代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5758726/
我是 C++ 的新手,我在使用这段代码时遇到了问题: string output_date(int day, int month, int year){ string date; if
所以我这样做了 tar cvzf test.zip FP 为了创建目录 FP 的 zip 但是,它会列出 zip 中的目录 FP/ FP/php/ FP/php/pdf/ FP/php/docs/ F
我正在尝试在 Swift、Xcode 7.3(所以是 Swift 2.2)中创建一个通用类,但我似乎无法让它通过编译器: protocol Struct1Protocol { } struct Str
我的测试用例是这样的: class FooTest extends PHPUnit_Framework_TestCase { /** @covers MyClass::bar */ f
我正在尝试将brew install wine作为使electron-builder工作的一步。但是我所能得到的只是以下响应: ==> Installing dependencies for wine
我这样做: string[,] string1 = {{"one", "0"},{"Two", "5"},{"Three","1"}}; int b = 0; for(int i = 0; i <=
我正在尝试使用 SetWindowsHookEx 键盘 Hook Notepad.exe。 如您所见,工作线程正在将其 ASCII 代码(即 wParam)发送到指定的服务器。 UINT WINAPI
我正在尝试将 ListView 实现到我的 Fragment 中,但无论我尝试什么,我都会得到一个 NullPointerException。我检查对象是否为 null 并记录是否为 null,看起来
我尝试在一行中对齐两个 div。使用 float left 属性,一切顺利。但是当我在 div 中使用图像时,它开始产生问题。 所以这是我的示例代码:- Some headi
我目前正在使用此代码来获取图像的灰度图像表示并以 (512, 370, 1) 的格式表示它大批。 img_instance = cv2.imread(df.iloc[i][x_col]) / 255.
总结 我正在创建一个简单的应用程序,它允许用户选择一个包含顶级窗口的进程。用户首先键入 native DLL(而非托管 DLL)的路径。然后用户键入将在 Hook 过程中调用的方法的名称。该方法不得返
我是一名优秀的程序员,十分优秀!