首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >bit64如何将长int存储在双

bit64如何将长int存储在双
EN

Stack Overflow用户
提问于 2014-11-07 06:13:57
回答 1查看 1.2K关注 0票数 2

当将整个数字存储为双倍时,在2^53之后就会发生精密恒星丢失:

代码语言:javascript
复制
> print(2^53, digits=20)
[1] 9007199254740992
> print(2^53+1, digits=20)
[1] 9007199254740992

R中的bit64包最多可以存储2^63个整数:

代码语言:javascript
复制
> library(bit64)
> print(as.integer64(2)^53, digits=20)
[1] 9007199254740992
> print(as.integer64(2)^53+1, digits=20)
[1] 9007199254740993

然而,看起来integer64对象只是用特殊类装扮成双倍的样子:

代码语言:javascript
复制
> typeof(as.integer64(2)^53)
[1] "double"

32位双倍怎么可能存储64位整数?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-07-28 19:43:52

我知道这是个老生常谈的问题,但我在一次搜索中发现了这个问题,我找到了答案。

作为mdsumner评论,从定义上说,double是64位.双倍存储在R的REALSXP类型中。bit64包将输入从其各种integer64方法转换为uint64_t (C99支持),并将64位存储在R的REALSXP中。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26795212

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档