首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么erlang整数使用28位?

为什么erlang整数使用28位?
EN

Stack Overflow用户
提问于 2014-08-05 09:57:50
回答 2查看 516关注 0票数 2

今天当我阅读Erlang关于效率指南的高级一章

小整数: 1字 32位架构:-134217729 64位架构:-576460752303423489 大整数: 3.N个词

(对不起,我试着在减价时用桌子,但没起作用,请原谅,这是我的第一个问题)

为什么使用28位或60位?剩下的4位的功能是什么?小还是大是由erlang判断的呢?32位架构意味着32位系统还是cpu?我的英语很差,我刚来二郎。泰克斯。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-08-05 10:21:25

其余四位用于识别数字以外的类型,如列表、元组、pids等。

做事情的另一种方法是在每个值前加上一个额外的字节或单词,以确定它是什么类型。但是,将值与类型说明符一起打包意味着许多值可以放在一个单词中。

VM是32位还是64位取决于它是如何编译的。启动Erlang时,如果将[64-bit]编译为64位程序,则会在横幅中看到它:

代码语言:javascript
复制
Erlang R16B03-1 (erts-5.10.4) [source] [64-bit] [smp:4:4] [async-threads:10] [hipe] [kernel-poll:false]

还可以使用erlang:system_info(wordsize)进行检查。

代码语言:javascript
复制
1> erlang:system_info(wordsize).
8

在这种情况下,字大小为8字节,即64位。

票数 8
EN

Stack Overflow用户

发布于 2014-08-05 13:54:45

作为一种动态类型语言,Erlang使用每个单词的四个位作为类型标记或"dope-field“,以标识该单词所引用的数据类型。Erlang实际上具有不确定的精度整数;如果整数在32位字结构上大于28位,在64位架构上大于60位,那么它将透明地被装箱到堆中的一个较大对象中,表示它所需的字节数。但是,装箱整数执行操作的效率较低,因为它们涉及一个额外的间接层。这就是为什么效率指南会注意到这一点。

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

https://stackoverflow.com/questions/25135972

复制
相关文章

相似问题

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