浮动&的Erlang二进制表示整数,差异?

时间:2011-07-05 12:00:32

标签: types binary erlang data-representation

获得了另一个Erlang二进制表示查询('这就是我现在正在阅读的内容,并且需要二进制协议实现)。

如果我正确理解了类型说明符,那么,对于“float”类型值,8字节表示看起来很好(这是在64位Win7上)。

1> <<A1/binary>> = <<12.3214/float>>.
<<64,40,164,142,138,113,222,106>>

然而令我难过的是,“整数”类型值的二进制表示。

2> <<A2/binary>> = <<32512/integer>>.
<<0>>
3> <<A3/binary>> = <<232512518/integer>>.
<<6>>
4> <<A5/binary>> = <<80/integer>>.
<<"P">>

为什么所有这些都用1个字节表示?有人可以解释一下吗?

1 个答案:

答案 0 :(得分:10)

您没有将Erlang术语转换为二进制表示形式。您正在使用二进制语法来构建二进制文件。使用整数将截断它们以适合一个字节:

3> <<255/integer>>. % Under one byte
<<"ÿ">>
4> <<256/integer>>. % "Over" one byte
<<0>>

试试这个:

5> term_to_binary(32512).
<<131,98,0,0,127,0>>
6> term_to_binary(232512518).
<<131,110,4,0,6,220,219,13>>
7> term_to_binary(80).
<<131,97,80>>

131是版本号,97是一个小整数(8位),98是一个大整数(32位),110(和111)用于bignum整数。其余的是实际数字的数据。

有关字节含义的更多信息,请参阅the documentation for the Erlang binary term format