- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在阅读Computer Systems: A Programmer's Perspective这本书,我正在尝试在配备 Intel Core i7 的 Macbook Pro 上执行它提供的代码。
但是有些代码并没有完全按照书中建议的那样运行。
这个 C 示例应该演示相同的 float 在存储在内存中和存储在寄存器中时会有所不同。
#include<stdio.h>
double recip( int denom )
{
return 1.0/(double) denom;
}
void do_nothing(){} /* to clear the register */
void fcomp( int denom)
{
double r1, r2;
int t1, t2;
r1 = recip(denom); /* stored in memory */
r2 = recip(denom); /* stored in register */
t1 = r1 == r2; /* Compares register to memory */
do_nothing(); /* Forces register save to memory */
t2 = r1 == r2; /* Compares memory to memory */
printf("test1 t1: r1 %f %c= r2 %f\n", r1, t1 ? '=' : '!', r2);
printf("test1 t1: r2 %f %c= r2 %f\n", r1, t2 ? '=' : '!', r2);
}
main(){
int demon = 10;
fcomp(demon);
}
与带有“O2”选项的gcc相比,书上建议的结果应该是:
test1 t1: r1 0.100000 != r2 0.100000
test2 t1: r1 0.100000 == r2 0.100000
但是,我得到了两个“==”,想知道为什么。对本书的环境设置有什么建议吗?非常感谢。
最佳答案
书中的示例(很可能)针对英特尔 CPU 中 x87 FPU 的特定属性:这种 FPU 类型的主要属性是它仅提供具有(可见的)80 位精度的寄存器。因此,当加载到 FPU 寄存器时,32 位或 64 位 float 将转换为 80 位 float 。此外,通常算术运算是以全精度执行的,因此如果一个值保存在 FPU 寄存器中供以后使用,它不会像复制到内存然后加载的值那样四舍五入为 32 或 64 位稍后回来。因此,一个值是否保存在寄存器中会有所不同。
然而,Mac OS X(我假设你在 Macbook 上使用)不使用 x87 FPU,它使用 SSE 单元:SSE 提供 32 位和 64 位浮点寄存器和操作,所以它没有区别一个值是否保存在寄存器中或存储在内存中关于其精度。每次操作后结果总是四舍五入。这通常也适用于 Windows 和 Linux 上的 64 位可执行程序。
例如32 位,Linux 或 Windows 情况不同。 x87 或 SSE 单元的使用取决于环境,通常使用 x87 FPU,因为 32 位机器可能不支持所需的 SSE2 指令,尽管最后一个没有 SSE2 的 CPU 是大约 10 年前制造的。
关于c - 学习所需的环境设置 "*Computer Systems:A Programmer' s Perspective*”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19308894/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!