Operacje na bitach
Operacje na bitach i bajtach w skrypcie TapHome — GETBIT, GETBITS, GETBYTE, SETBYTE, SETBIT, SETBITS, przesunięcia bitowe oraz bitowe AND/OR.
GETBIT
Zwraca wartość bitu na podanej pozycji.
GETBIT(number, bit_position)Argumenty:
- number - liczba, z której wyciągamy wartość konkretnego bitu
- bit_position - pozycja bitu, licząc od 0, od prawej
Przykłady:
- GETBIT(2, 0) → pierwszy bit liczby 2 (0b0010) to 0
- GETBIT(4,2) → trzeci bit liczby 4 (0b0100) to 1
GETBITS
Zwraca wartość określonej liczby bitów z określonej pozycji.
GETBITS(number, start_bit, number_of_bits)Przykłady:
- GETBITS(216, 3, 2) → liczba 216 = 0b11011000; wartość 4. bita od prawej to 1, 5. bit to 1, więc wynik to 0b0011 = 3
- GETBITS(0xFF, 0, 4) → liczba 0xFF = 255 = 0b1111 1111; wartość pierwszych 4 bitów od prawej to 0b1111 = 0xF = 15
GETBYTE
Zwraca wartość bajtu w zadanej liczbie.
GETBYTE( number, byte_position )Argumenty:
- number - liczba, z której wyciągamy wartość konkretnego bajtu
- byte_position - pozycja bajtu, zaczynając od 0, od prawej
Przykłady:
GETBYTE(256, 0) → 0001 0000 0000 → 0
GETBYTE(256, 1) → 0001 0000 0000 → 1
GETBYTE(259, 0) → 0001 0000 0011 → 3SETBYTE
Nadaje nową wartość wskazanemu bajtowi w podanej liczbie i zwraca nową liczbę.
SETBYTE( number, byte_position, new_value )Przykłady:
SETBYTE(1, 0, 0) → 0
SETBYTE(256, 0, 255) → 511
SETBYTE(256, 1, 1) → 256
SETBYTE(259, 1, 2) → 515SETBIT
Nadaje nową wartość wskazanemu bitowi w podanej liczbie i zwraca nową liczbę.
SETBIT(number, bit_position, new_value)Argumenty:
- number - liczba do zmodyfikowania
- bit_position - pozycja bitu, zaczynając od 0, od prawej
- new_value - 0 lub 1 – wartość, która ma być ustawiona na określony bit
Przykłady:
- SETBIT(1, 1, 1) → 3
- SETBIT(3, 1, 1) → 3
- SETBIT(4, 2, 0) → 4
- SETBIT(12, 1, 0) → 14
SETBITS
Nadaje nową wartość wskazanym bitom w podanej liczbie i zwraca nową liczbę.
SETBITS(number, start_bit, number_of_bits, new_value)Przykłady:
- SETBITS(192, 4, 2, 3) → 240
- SETBITS(192, 5, 2, 3) → 224
« (LEFT BIT SHIFT)
8 << 2 (32)Excel: BITLSHIFT(number, shift_amount)
» (RIGHT BIT SHIFT)
32 >> 2 (8)Excel: BITRSHIFT(number, shift_amount)
& (BITWISE AND)
3 & 1 (1)Excel: BITAND(number1, number2)
| (BITWISE OR)
2 | 1 (3)Excel: BITOR(number1, number2)
Zobacz przykład operacji na bitach w Google Sheets: https://docs.google.com/spreadsheets/d/1hF5FMpGMJbgYh-YLwWrq2n186_ATyGyLUb689__IhLY/edit?usp=sharing
Lub wypróbuj interaktywne narzędzie na http://bitwisecmd.com/