【发布时间】:2013-01-12 15:51:49
【问题描述】:
【问题讨论】:
-
你需要对 String#unpack 有同样的兴趣。我知道这些是用于创建和读取二进制文件的,我还没有使用过它们。
标签: ruby ruby-1.9.3
【问题讨论】:
标签: ruby ruby-1.9.3
我会举几个例子,和你一起学习:
[1,2,3,4].pack("CCCC")
=> "\x01\x02\x03\x04"
所以序列化为无符号字符。新字节中的每个字母。
[1,2,3,4].pack("CCXCC")
=> "\x01\x03\x04"
[1,2,3,4].pack("CCXXC")
=> "\x03"
将“X”视为退格指令
[1,2,3,4].pack("CCxC")
=> "\x01\x02\x00\x03"
[1,2,3,4].pack("CCxxC")
=> "\x01\x02\x00\x00\x03"
'x' 放置零值字节。
[1,2,3,4].pack("CC@C")
=> "\x01\x03"
[1,2,3,4].pack("CC@@C")
=> "\x01\x03"
[1,2,3,4].pack("CC@@CC")
=> "\x01\x03\x04"
[1,2,3,4].pack("CC@CC")
=> "\x01\x03\x04"
[1,2,3,4].pack("CC@C@C")
=> "\x01\x04"
[1,2,3,4].pack("CC@C@@C")
=> "\x01\x04"
'@' 似乎是单个退格,但不会同时支持多个操作。最后一个作为解释与文档中的文本完全无关:
@移动到绝对位置
但它似乎在做什么。
编辑顺便说一句,@ 在unpack 的上下文中看起来更合乎逻辑:
[1,2,3,4,5].pack("CCCCC").unpack("CCC@CCCCC@CC")
=> [1, 2, 3, 1, 2, 3, 4, 5, 1, 2]
再次从头开始解包。
EDIT2 以下是解包上下文中其他两个指令的解释:
[1,2,3,4,5].pack("CCCCC").unpack("CCCXC")
=> [1, 2, 3, 3]
[1,2,3,4,5].pack("CCCCC").unpack("CCCXXC")
=> [1, 2, 3, 2]
[1,2,3,4,5].pack("CCCCC").unpack("CCCxC")
=> [1, 2, 3, 5]
所以“x”忽略下一个要解码的字节,而“X”将使前一个字节成为下一个要再次读取的字节。 'X' 可以堆叠。
这是我第一次尝试总结结果:
pack:
unpack:
注意读者是我为了便于解释而编造的一个词,绝不是正式的。
EDIT3这里也是“\x01”符号的解释:
a = [17, 22, 31]
=> [17, 22, 31]
a.pack("CCC")
=> "\x11\x16\x1F"
这似乎代表十六进制表示。我链接的所有网站显然都使用十进制表示。否则,可以看出这些是给定数字的十六进制表示。
【讨论】:
\x 会出现在输出中的每个数字之前。
x
1 表示为\x01。我想学!那我会问你更多的问题。