2

阅读销售点系统的文档,这里是他们给出的一个面具的例子,它应该告诉你选择了哪些座位。我想不通。我完全理解位掩码。这个例子是错的吗?

功能

此系统变量是一个包含座椅过滤器掩码的八字符串。

类型/尺寸

A8

句法

@Filter_mask

过滤器掩码用法

此系统变量是只读的。

Filter_mask 示例

以下是过滤器掩码的示例:

80000000 - seat 1 is active (@filter_active ="Y")
00000001 - seat 32 is active (@filter_active = "Y")
50A00000 - seats 2,4,9 and 11 are active (@filter_active = "Y")
00000000 - filter inactive, no seats
4

4 回答 4

2

一次将每个数字转换为 4 位二进制。

80000000 -> 1000 0000 ....
50A00000 -> 0101 0000 1010 ...
于 2011-06-07T19:43:54.423 回答
2

这些是 8 位十六进制数,最多可以存储 32 位二进制数。

(16^8 = 2^32 = 4,294,967,296)

在二进制表示中,每个数字对应一个座位:

   hex               binary
80000000 = 10000000000000000000000000000000
00000001 = 00000000000000000000000000000001
50a00000 = 01010000101000000000000000000000
00000000 = 00000000000000000000000000000000

第一个二进制位用于座位#1,最后一个二进制位用于座位#32。因为他们给你一个 8 字符的字符串,你可能想把它解析成一个 32 位的值来做掩码运算。在您的目标语言中查找“十六进制字符串到整数”,您会发现如下内容:

在 Python 中将十六进制字符串转换为 int

注意:当您查看此类内容时,Google 可以立即为您进行基本转换,例如(“0x50a00000 in binary”),但 Wolfram Alpha 做的更多:

http://www.wolframalpha.com/examples/NumberBases.html

于 2011-06-07T19:52:47.140 回答
1

这个例子似乎是对的。他们只是颠倒了最高有效位和最低有效位,并对位位置使用基于 1 的索引(除了将数据保存为 ASCII 而非 4 个字节的十六进制)。因此,如果n设置了位(LSB 为位 #0,或值为00000001),您将获得座位号31-n+1

于 2011-06-07T19:41:36.877 回答
1

你的面具如下:

Seat 1: 0x80000000
Seat 2: 0x40000000
Seat 3: 0x20000000
Seat 4: 0x10000000
Seat 5: 0x08000000
...
Seat 31:0x00000002
Seat 32:0x00000001

或更笼统地说:

mask = 1 << (32 - seatno)

例子:

0x50A00000 = 0x40000000 | 0x10000000 | 0x00800000 | 0x00200000

因此座位为 2、4、9 和 11。

于 2011-06-07T19:46:30.713 回答