Bitové operácie
Manipulácia s bitmi a bajtmi v skripte TapHome — GETBIT, GETBITS, GETBYTE, SETBYTE, SETBIT, SETBITS, posuny bitov a bitové AND/OR.
GETBIT
Vráti hodnotu bitu na určenej pozícii.
GETBIT(number, bit_position)Argumenty:
- number - číslo, z ktorého sa má hodnota konkrétneho bitu získať
- bit_position - pozícia bitu, počítaná od 0 sprava
Príklady:
- GETBIT(2, 0) → prvý bit čísla 2 (0b0010) je 0
- GETBIT(4,2) → tretí bit čísla 4 (0b0100) je 1
GETBITS
Vráti hodnotu určeného počtu bitov na zadanom mieste.
GETBITS(number, start_bit, number_of_bits)Príklady:
- GETBITS(216, 3, 2) → číslo 216 = 0b1101 1000; hodnota 4. bitu zľava je 1, 5. bitu je 1, takže výsledok je 0b0011 = 3
- GETBITS(0xFF, 0, 4) → číslo 0xFF = 255 = 0b1111 1111; hodnota prvých 4 bitov sprava je 0b1111 = 0xF = 15
GETBYTE
Vráti hodnotu bajtu v zadanom čísle.
GETBYTE( number, byte_position )Argumenty:
- number - číslo, z ktorého sa má hodnota konkrétneho bajtu získať
- byte_position - pozícia bajtu, počítaná od 0 sprava
Príklady:
GETBYTE(256, 0) → 0001 0000 0000 → 0
GETBYTE(256, 1) → 0001 0000 0000 → 1
GETBYTE(259, 0) → 0001 0000 0011 → 3SETBYTE
Priradí novú hodnotu špecifikovanému bajtu v zadanom čísle a vráti výsledné číslo.
SETBYTE( number, byte_position, new_value )Príklady:
SETBYTE(1, 0, 0) → 0
SETBYTE(256, 0, 255) → 511
SETBYTE(256, 1, 1) → 256
SETBYTE(259, 1, 2) → 515SETBIT
Priradí novú hodnotu špecifikovanému bitu v čísle a vráti nové číslo.
SETBIT(number, bit_position, new_value)Argumenty:
- number - číslo, ktoré sa má upraviť
- bit_position - pozícia bitu, počítaná od 0 sprava
- new_value - 0 alebo 1 – hodnota, ktorá sa má nastaviť na daný bit
Príklady:
- SETBIT(1, 1, 1) → 3
- SETBIT(3, 1, 1) → 3
- SETBIT(4, 2, 0) → 4
- SETBIT(12, 1, 0) → 14
SETBITS
Priradí novú hodnotu zadaným bitom v čísle a vráti nové číslo.
SETBITS(number, start_bit, number_of_bits, new_value)Príklady:
- SETBITS(192, 4, 2, 3) → 240
- SETBITS(192, 5, 2, 3) → 224
« (POSUN BITOV DOĽAVA)
8 << 2 (32)Excel: BITLSHIFT(number, shift_amount)
» (POSUN BITOV DOPRAVA)
32 >> 2 (8)Excel: BITRSHIFT(number, shift_amount)
& (BITOVÉ AND)
3 & 1 (1)Excel: BITAND(number1, number2)
| (BITOVÉ OR)
2 | 1 (3)Excel: BITOR(number1, number2)
Pozrite si príklad bitových operácií v Google Sheets: https://docs.google.com/spreadsheets/d/1hF5FMpGMJbgYh-YLwWrq2n186_ATyGyLUb689__IhLY/edit?usp=sharing
Alebo vyskúšajte interaktívny nástroj na http://bitwisecmd.com/