What is a bitmask and a mask?

前端 未结 3 989
时光取名叫无心
时光取名叫无心 2020-12-02 07:44

On the PHP documentation about JSON it mentions the word bitmask. Wikipedia has it defined as a mask. I don\'t understand either bitmask or mask or how they are useful. Can

相关标签:
3条回答
  • 2020-12-02 08:31

    It is just a number, as represented in binary. For example, let's say I have 8 boolean values (true or false) that I want to store. I could store it as an array of 8 booleans, or I could store it as a single byte (8 bits), each of which store one of the booleans (0 = false, 1 = true).

    At this point, I can easily manipulate my byte so that I can (1) set specific bits to be on or off (true or false), and (2) check whether specific bits are on or off.

    • To set a bit to 1: mask = mask | (1 << bitIndex)
    • To set a bit to 0: mask = mask & ~(1 << bitIndex)
    • To get a bit (to be able to check it): (mask & (1 << bitIndex)) != 0

    All of these operations use the left-shift operator, which moves bits up from least-significant to most-significant positions.

    0 讨论(0)
  • 2020-12-02 08:38

    Bits and Bytes

    In computing, numbers are internally represented in binary. This means, where you use an integer type for a variable, this will actually be represented internally as a summation of zeros and ones.

    As you might know, a single bit represents one 0 or one 1. A concatenation of eight of those bits represent a Byte, e.g. 00000101, which is the number 5. I presume you know how numbers are represented in binary, if not, take a look here.

    In PHP a number is (mostly) 4 Bytes long. This means that your number actually uses 32 bits of the internal storage. But for simplicity reasons, throughout this answer I will use 8 bit numbers.

    Storing states in bits

    Now imagine you want to create a program that holds a state, which is based on multiple values that are one(true) or zero(false). One could store these values in different variables, may they be booleans or integers. Or instead use a single integer variable and use each bit of its internal 32 bits to represent the different true and falses.

    An example: 00000101. Here the the first bit (reading from right to left) is true, which represents the first variable. The 2nd is false, which represents the 2nd variable. The third true. And so on...

    This is a very compact way of storing data and has many usages.

    Bit Masking

    This is where bit masking comes in. It sounds complex but actually it's very simple.

    Bit masking allows you to use operations that work on bit-level.

    • Editing particular bits in a byte(s)
    • Checking if particular bit values are present or not.

    You actually apply a mask to a value, where in our case the value is our state 00000101 and the mask is again a binary number, which indicates the bits of interest.

    By performing binary operations on the mask and the state one could achieve the following:

    • The AND operator extracts a subset of the bits in the state
    • The OR operator sets a subset of the bits in the state
    • The XOR operator toggles a subset of the bits in the state

    If we want to set a particular value to true, we could do this by using the OR operator and the following bit mask:

    Mask:   10000000b
    Value:  00000101b
    ---- OR ---------
    Result: 10000101b
    

    Or one could select a particular value from the state by using the AND operator:

    Mask:   00000100b
    Value:  00000101b
    ---- AND ---------
    Result: 00000100b
    

    I suggest you to take some deeper look into it and get familiar with the jargon. A good start may be this link.

    Goodluck!

    0 讨论(0)
  • 2020-12-02 08:40

    In essence, Bitmask is a list of boolean flags (for example isAlive, isMoving, etc) compressed into a single field, usually an integer. It can cut quite a significant amount of JSON string size or memory footprint.

    This can be significant especially in PHP where a single boolean in an array can take the same amount of RAM as an integer. There is a very simple Bitmask guide that will explain step by step everything you need to know including how and when to use it.

    0 讨论(0)
提交回复
热议问题