1
1
Fork 0
mirror of https://github.com/QB64-Phoenix-Edition/QB64pe.git synced 2024-06-29 10:30:36 +00:00
QB64-PE/internal/help/STATIC.txt
SteveMcNeill 33adc04fc4 Add temp folder to repo. It's necessary as well!
Just more initial setting on... nothing much to see here.
2022-04-28 13:39:56 -04:00

100 lines
3.9 KiB
Plaintext

The {{KW|STATIC}} keyword is used in declaration statements to control where variables are stored.
{{PageSyntax}}
:{{KW|STATIC}} {{Parameter|variableName}}[()] [{{KW|AS}} {{Parameter|dataType}}][, ...]
{{PageSyntax}}
:{[[SUB]]|[[FUNCTION]]} {{Parameter|procedureName}} [({{Parameter|parameterList}})] STATIC
{{PageDescription}}
* A STATIC list can be used in [[SUB]] and [[FUNCTION]] procedures to designate one or more variables to retain their values.
* Variables and arrays with static storage will retain their values in between procedure calls. The values may also be used recursively.
:* {{Parameter|variableName}} may include a type suffix or use [[AS]] to specify a type other than the default [[SINGLE]] type.
:* Arrays with static storage are declared by specifying empty parenthesis following the array name. See [[Arrays]]
* STATIC can be used after the name of a [[SUB]] or [[FUNCTION]] in the procedure to force all variables to retain their values.
* '''Recursive procedures may be required to be STATIC to avoid a Stack Overflow! QB64 programs may just close!'''
* [[$STATIC]] defined program [[arrays]] cannot be [[REDIM|re-sized]] or use [[_PRESERVE]].
''Example 1: Finding the binary bit settings from a 32 bit [[LONG]] register return using recursion.
{{CodeStart}} '' ''
{{Cl|INPUT}} "Enter a numerical value to see binary value: ", num&
{{Cl|PRINT}} Bin$(num&)
{{Cl|END}}
{{Cl|FUNCTION}} Bin$ (n&) {{Cl|STATIC}} 'comment out STATIC to see what happens!
{{Cl|DIM}} p%, s$
{{Cl|IF...THEN|IF}} 2 ^ p% > n& {{Cl|THEN}}
p% = 0
{{Cl|ELSE}}
{{Cl|IF...THEN|IF}} n& {{Cl|AND (boolean)|AND}} 2 ^ p% {{Cl|THEN}} s$ = "1" + s$ {{Cl|ELSE}} s$ = "0" + s$
{{Cl|IF...THEN|IF}} n& > 2 ^ p% {{Cl|THEN}}
p% = p% + 1
s$ = Bin$(n&) 'recursive call to itself
{{Cl|ELSE}}: p% = 0
{{Cl|END IF}}
{{Cl|END IF}}
{{Cl|IF...THEN|IF}} s$ = "" {{Cl|THEN}} Bin$ = "0" {{Cl|ELSE}} Bin$ = s$
{{Cl|END FUNCTION}} '' ''
{{CodeEnd}}
: ''Explanation:'' The [[FUNCTION]] above returns a [[STRING]] value representing the bits ON in an [[INTEGER]] value. The string can be printed to the screen to see what is happening in a port register. '''STATIC''' keeps the function from overloading the memory "Stack" and is normally REQUIRED when recursive calls are used in Qbasic! '''QB64 procedures will close without warning or error!'''
''Example 2:'' Using a static array to cache factorials, speeding up repeated calculations:
{{CodeStart}}
{{Cl|PRINT}} Factorial(0)
{{Cl|PRINT}} Factorial(5)
{{Cl|PRINT}} Factorial(50
{{Cl|FUNCTION}} Factorial# ( n {{Cl|AS}} {{Cl|DOUBLE}} )
{{Cl|CONST}} maxNToCache = 50
{{Cl|STATIC}} resultCache() {{Cl|AS}} {{Cl|DOUBLE}}
{{Cl|STATIC}} firstCall {{Cl|AS}} {{Cl|INTEGER}}
' The lookup table is initially empty, so re-size it..
{{Cl|IF...THEN|IF}} firstCall = 0 {{Cl|IF...THEN|THEN}}
firstCall = -1
{{Cl|REDIM}} resultCache(maxNToCache) {{Cl|AS}} {{Cl|DOUBLE}}
' ..and pre-calculate some factorials.
resultCache(0) = 1
resultCache(1) = 1
resultCache(2) = 2
{{Cl|IF...THEN|END IF}}
' See if we have the result cached. If so, we're done.
{{Cl|IF...THEN|IF}} n <= maxNToCache {{Cl|IF...THEN|THEN}}
{{Cl|IF...THEN|IF}} resultCache(n) <> 0 {{Cl|IF...THEN|THEN}}
Factorial = resultCache(n)
{{Cl|EXIT FUNCTION}}
{{Cl|IF...THEN|END IF}}
{{Cl|IF...THEN|END IF}}
' If not, we use recursion to calculate the result, then cache it for later use:
resultCache(n) = {{Cl|INT}}(n) * Factorial({{Cl|INT}}(n) - 1)
Factorial = resultCache(n)
{{Cl|END FUNCTION}}
{{CodeEnd}}
{{OutputStart}}
1
120
3.041409320171338D+64
{{OutputEnd}}
{{PageSeeAlso}}
* [[DIM]], [[REDIM]], [[COMMON]]
* [[SUB]], [[FUNCTION]]
* [[TYPE]], [[Arrays]]
* [[$STATIC]], [[$DYNAMIC]] {{text|([[Metacommand]]s)}}
* [[Data types]]
{{PageNavigation}}
<