BYREF (parameters)
- Source: https://www.freebasic.net/wiki/wikka.php?wakka=KeyPgByref
- Last revised: 2024-03-07
Declaration specifier to explicitly pass a parameter by reference
Syntax
` Byref param as datatype
`
Usage
` [ declare ] { sub | function } proc_name ( Byref param as datatype )
`
Description
Passes a variable by reference, that is its address, to a subroutine or function. When a variable is passed by reference, the contents of the variable can be changed by the target subroutine or function.
In -lang qb and -lang fblite dialects, Byref is the default parameter passing convention, unless Option ByVal is in effect.
Opposite of ByVal.
Note: A constant or a literal expression can also be passed to such a procedure (which gets by reference), but they are obviously not modifiable from the procedure body. In that case, the compiler passes by reference a temporary variable initialized with the constant or the literal expression.
Note: Since fbc version 1.20.0, arguments of STRINGN type are copied to a temporary variable when passed to BYREF ZSTRING (or BYVAL ZSTRING PTR) parameters (since there is no expectation that STRINGN will have it's own terminating null character) and copied back after the call.
Warning: When passing by reference, it is recommended to pass an argument of the same type (or fully compatible, like a derived type for example) as that of the declared parameter. Although in some cases the compiler accepts to pass a different type, often the result is not the one expected.
Examples
start GeSHi
Dim MyVar As Integer
Sub ChangeVar(ByRef AVar As Integer)
AVar = AVar + 1
End Sub
MyVar = 1
Print "MyVar: "; MyVar 'output = 1
ChangeVar MyVar
Print "MyVar: "; MyVar 'output = 2
Sleep
Endend GeSHi
Dialect Differences
- In -lang fb dialect,
Byvalis the default parameter passing convention for all built-in types exceptStringand user-definedTypewhich are passedByrefby default. TheZstringandWstringbuilt-in types are also passedByrefby default, but passingByvalis forbidden. Arrays are always passedByrefand the use of the specifierByreforByvalis forbidden. - In -lang qb and -lang fblite dialects,
Byrefis the default parameter passing convention.
Differences from QB
- New to FreeBASIC
See also
- Passing Arguments to Procedures
DeclareByValByref (function results)Byref (variables)
Back to DocToc