Syntax: TYPE[<typename>]( a [, b [, ...] ] )
Typ: Funktion
Kategorie: Speicherverwaltung
TYPE() erzeugt einen temporären Typen und stellt damit eine noch kürzere Alternative als WITH dar, wenn alle Records geändert werden.
Beispiel:
TYPE Example
AS INTEGER field1
AS INTEGER field2
END TYPE
DIM ex AS Example
' Standard-Methode zur Befüllung der Records
ex.field1 = 1
ex.field2 = 2
' WITH-Methode
WITH ex
.field1 = 1
.field2 = 2
END WITH
' TYPE()-Methode
ex = TYPE( 1, 2 )
Um den Code besser lesbar zu gestalten, kann auch diese Syntax verwendet werden:
ex = type<Example>( 1, 2 )
Wie bereits angesprochen, kann TYPE() nur verwendet werden, wenn alle Records eines UDTs geändert werden. Es gibt aber auch noch andere Verwendungsmöglichkeiten.
2. Beispiel: Funktionsaufruf mit Übergabe eines temporären UDTs
Type S
As Single x, y
End Type
Sub test ( v As S )
Print "S", v.x, v.y
End Sub
test( Type( 1, 2 ) )
test( Type<S>( 1, 2 ) )
Eine ähnliche Funktionalität bietet die Nutzung eines Constructors:
Type S
Declare Constructor (a As Single, b As Single)
As Single x, y
End Type
Constructor S (a As Single, b As Single)
x = a
y = b
End Constructor
Sub test ( v As S )
Print "S", v.x, v.y
End Sub
test( S( 1, 2 ) )
Sleep
Unterschiede zu QuickBASIC:
- neu in FreeBASIC
Unterschiede zu früheren Versionen von FreeBASIC:
- Die Verwendung von TYPE als Funktion ist erst seit FreeBASIC v0.16 möglich
Siehe auch:
TYPE (UDT), TYPE (Forward Referencing), WITH