1
1
Fork 0
mirror of https://github.com/QB64Official/qb64.git synced 2024-07-16 18:55:13 +00:00
qb64/internal/help/_SHL.md

74 lines
1.6 KiB
Markdown
Raw Normal View History

The [_SHL](_SHL) function is used to shift the bits of a numerical value to the left.
## Syntax
> result = [_SHL](_SHL)(numericalVariable, numericalValue)
## Parameter(s)
* numericalVariable is the variable to shift the bits of and can be of the following types: [INTEGER](INTEGER), [LONG](LONG),[_INTEGER64](_INTEGER64), or [_BYTE](_BYTE).
* Integer values can be signed or [_UNSIGNED](_UNSIGNED).
* numericalValue is the number of places to shift the bits.
* While 0 is a valid value it will have no affect on the variable being shifted.
## Description
* Allows for multiplication of a value by 2 faster than normal multiplication (see example 2 below).
* Bits that reach the end of a variable's bit count are dropped (when using a variable of the same type - otherwise they will carry over).
* The type of variable used to store the results should match the type of the variable being shifted.
## Availability
* Version 1.3 and up.
## Example(s)
```vb
A~%% = 1 'set right most bit of an_UNSIGNED _BYTE
PRINT A~%%
PRINT _SHL(A~%%,7)
B~%% = _SHL(A~%%,8) 'shift the bit off the left 'edge'
PRINT B~%%
```
```text
1
128
0
```
```vb
A~%% = 1
FOR I%% = 0 TO 8
PRINT _SHL(A~%%, I%%)
NEXT I%%
```
```text
1
2
4
8
16
32
64
128
256
```
* Note: When directly [PRINT](PRINT)ing to screen, the result is calculated internally using a larger variable type so the left most bit is carried to the next value.
* To avoid this store the result in a variable of the same type before printing.
## See Also
* [_SHR](_SHR), [INTEGER](INTEGER), [LONG](LONG)
* [_BYTE](_BYTE), [_INTEGER64](_INTEGER64)