- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
关于 PHP documentation关于 JSON,它提到了位掩码这个词。维基百科将其定义为面具。我不明白位掩码或掩码或它们是如何有用的。有人可以使用外行的术语而不是行话来解释这些术语吗?
最佳答案
位和字节
在计算中,数字在内部以二进制表示。这意味着,当您为变量使用整数类型时,这实际上在内部表示为 0 和 1 的总和。
您可能知道,一位代表一个 0
或一个 1
.八个这些位的串联表示一个字节,例如00000101
,这是数字 5。
我想你知道数字是如何用二进制表示的,如果不知道,看看 here .
在 PHP 中,一个数字(大部分)是 4 字节长。这意味着您的号码实际上使用了 32 位的内部存储空间。但为了简单起见,在整个答案中,我将使用 8 位数字。
以位为单位存储状态
现在假设您要创建一个保存状态的程序,该状态基于多个值,即一( true
)或零( false
)。可以将这些值存储在不同的变量中,可以是 bool 值或整数。 或者改为 使用单个整数变量并使用其内部 32 位的每一位来表示不同的真假。
一个例子:00000101
.这里第一位(从右到左读取)为真,代表第一个变量。第二个为假,代表第二个变量。第三个是真的。等等...
这是一种非常紧凑的数据存储方式,用途广泛。
位屏蔽
这就是位掩码的用武之地。听起来很复杂,但实际上非常简单。
位掩码允许您使用在位级别上工作的操作。
00000101
掩码也是一个二进制数,表示感兴趣的位。
Mask: 10000000b
Value: 00000101b
---- OR ---------
Result: 10000101b
Mask: 00000100b
Value: 00000101b
---- AND ---------
Result: 00000100b
关于bitmask - 什么是位掩码和掩码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31575691/
关于 PHP documentation关于 JSON,它提到了位掩码这个词。维基百科将其定义为面具。我不明白位掩码或掩码或它们是如何有用的。有人可以使用外行的术语而不是行话来解释这些术语吗? 最佳答
阅读销售点系统的文档,这里是他们给出的 mask 示例,该 mask 应该告诉您选择了哪些座位。我无法弄清楚这一点。我完全理解位掩码。这个例子是不是错了? 函数 该系统变量是一个八个字符的字符串,其中
我试图从一个二进制文件中取出四个字节,并将它们转换成一个位掩码,代表数据的零和元数据的 1。 我假设我需要通过将它们组合在一起来将它们转换为 int,然后通过移位来确定是否设置了位位置。 我无法弄清楚
这是我的合作伙伴想出的代码,但出于某种原因,我无法联系到他,问他应该如何工作。我现在已经经历了很多次,但似乎无法得到我应该得到的答案。 /** * bitMask - Generate a mask
[旗帜] public enum ShowProductOn : short { HomePage = 1, SalesPage = 2, NewsLetter = 4 };
BufferedImage 类实现 Transparency,它具有三个值: OPAQUE表示不透明。 TRANSLUCENT 表示每个像素的 Alpha 值都在 0 到 1 之间。 BITMASK表
我对这个任务有疑问。 http://www.spoj.com/problems/LINEUP/看起来很简单,但我的解决方案失败了。我得到错误的结果。任何人都可以帮忙弄清楚吗?非常感谢您的帮助。 :-)
我希望能够在 Swift 中正确读取 NSUnderlineStyle 的值。 它比看起来更复杂。 首先,快速回顾一下。 NSUnderlineStyle 是具有以下值的枚举: NSUnderline
我试图避免英雄和硬币之间的碰撞,但不是英雄和草地之间的碰撞。一旦我将碰撞位掩码应用于 Hero,我的 Hero 就会穿过所有东西。我希望它穿过硬币而不是穿过草地。这是代码,有什么想法吗? let HE
所以我决定创建一个控制台类来替代 std::cout console = GetStdHandle(STD_OUTPUT_HANDLE); this->current_color =
我正在研究基于位板的国际象棋引擎,其中一项大量执行的操作是设置/清除无符号 64 位整数中的位。由于我不太了解哪些代码可以在某些处理器上“更快”地运行,因此我无法完全理解这一点。 设置和清除位是一个非
我正在尝试使用 numpy 将几个掩码( bool 数组)转换为一个位掩码,虽然理论上可行,但我觉得我做了太多操作。 例如创建我使用的位掩码: import numpy as np flags = [
例子 self.accessibilityTraits |= UIAccessibilityTraitAdjustable; 添加了 UIAccessibilityTraitAdjustable 选项
我开始使用 ini_get_all 函数来检索共享主机服务器上的所有配置选项。最后我得到了这个数组 block : [allow_call_time_pass_reference] => Array
目前我将一组项目的组合存储为单个整数(位掩码值),如下例所示: 示例: 1 - Orange 2 - Banana 4 - Cherry 8 - Apple 然后如果用户选择Orange (1) 和A
我正在使用 Python 编程并使用 SQLAlchemy 来存储营业时间。 营业时间由三部分组成: 星期几以二进制形式存储为位掩码 营业时间, 企业关闭的时间。 位掩码是这样工作的。有 7 个数字,
我对一种“扩展位”的快速方法很感兴趣,它可以定义如下: 设 B 是一个有 n 位的二进制数,即 B\in {0,1}^n 设P为B中所有1/true位的位置,即1 A 给定 B,使得 Ap[j] ==
我使用嵌入式东西 (PIC),在我见过的所有 C 代码中,如果函数采用多个标志或少量枚举值,它是作为手工制作的 int 位掩码完成的,就像这样: /* first flag */ #define M
所以,最近开始学习iOS开发和Objective-C,主要是利用斯坦福在iTunes U上的免费类(class)。 我最终偶然发现了位掩码,这是 iOS API 中广泛使用但我不是很熟悉的东西。我已经
我想将不同长度的二维数组存储为 AwkwardArray,将它们存储为 Parquet,然后再次访问它们。 问题是,从 Parquet 加载后,格式是 BitMaskedArray并且访问性能有点慢。
我是一名优秀的程序员,十分优秀!