Using Generics
In the .NET Framework, you can use generics to customize a method, class, structure, interface, field, or property according to the data type that it acts upon. Instead of writing a method, class, structure, interface, field, or property for a particular type, you can write it to use any type. When a generic is declared, the type is specified. For example, in C#, if you use the generic type parameter T
, then you can write a List<T>
class that is declared as either List<int>
, List<string>
, or List<MyClass>
.
With .NET Framework interoperability, you can define DotNet variables for generics. You cannot specify generic type names in C/AL. When a generic is instantiated by a constructor in C/AL, all type names are set to the System.Object type. For example, if you have a mylist DotNet variable for the System.List<T> generic, you create an instance of mylist in C/AL as shown. mylist is instantiated as a List<Object>
type.
mylist := mylist.List();
If a method returns an instance of a generic whose type name is defined, then the type name is applied. In the following C/AL example, the method returns a List<String>
instance, and mylist is instantiated as a List<String>
type.
mylist := x.GetAStringList();
Example
The following C/AL example constructs a string list, fills the list with data, and then uses the Item method to validate whether the list contains the expected data. The Item method is equivalent to a C# index operator.
Variable name | Data Type | SubType | Length |
---|---|---|---|
varDotNet |
DotNet |
'mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089'.System.Collections.Generic.List`1 |
|
textResult |
Text |
30 |
|
i |
Integer |
||
capacity |
Integer |
capacity := 5;
varDotNet := varDotNet.List(capacity);
FOR i:= 0 TO (capacity-1) DO
varDotNet.Add(FORMAT(i));
IF varDotNet.Count <> capacity THEN
ERROR('Wrong list count, expected {0}, actual {1}', capacity,
varDotNet.Count);
FOR i:= 0 TO (capacity-1) DO
BEGIN
textResult := varDotNet.Item(i);
IF textResult <> FORMAT(i) THEN
ERROR('List index [%1] contains the wrong data, expected %2, actual
%3', i, FORMAT(i), textResult);
END;