答案 0 :(得分:5)
我会举几个例子,并会和你一起学习:
[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"
'@'似乎是一个退格,但不会同时支持多个操作。最后一个解释与文档中的文本完全无关:
@移动到绝对位置
但它似乎正在做什么。
编辑 BTW @
在查看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"
似乎这代表十六进制表示。我链接的所有网站显然都使用十进制表示。否则,可以看出这些是给定数字的十六进制表示。