[fpc-pascal] Open vs dynamic arrays
Mark Morgan Lloyd
markMLl.fpc-pascal at telemetry.co.uk
Sun Apr 22 12:54:21 CEST 2012
Michael Van Canneyt wrote:
> On Sun, 22 Apr 2012, Mark Morgan Lloyd wrote:
>
>> cobines wrote:
>>> 2012/4/22 Mark Morgan Lloyd <markMLl.fpc-pascal at telemetry.co.uk>:
>>>> but I'm not sure why that works when it
>>>> didn't earlier (i.e. before I'd started using array of const).
>>>
>>> You said you used
>>> DbgArray= array of integer
>>>
>>> then I assume this declaration?
>>> procedure ClrDebug(const panels: DbgArray);
>>>
>>> If so the parameter is a dynamic array not open array and you cannot
>>> call it with constant array:
>>>
>>> var
>>> arr: DbgArray;
>>> begin
>>> ClrDebug([DbgKey, DbgCode1, DbgTx]); //Won't work
>>> SetLength(arr, ...);
>>> arr[0] := ...
>>> ...
>>> ClrDebug(arr);// This works
>>> end;
>>>
>>>
>>> This on the other hand is an open array parameter:
>>> procedure ClrDebug(const panels: array of integer);
>>
>> Thanks, succinct. So if I understand this correctly it's one of the
>> very rare cases where one has to write out the type of a parameter in
>> full, rather than using an earlier declaration.
>
> It results in different declarations.
>
> type
> DbgArray = array of integer;
>
> procedure ClrDebug(const panels: DbgArray);
>
> Defines a procedure that accepts a dynamic array of type DbgArray.
> You cannot have "constant dynamic arrays", as they are managed on the
> heap and reference counted.
>
> On the other hand
>
> procedure ClrDebug(const panels: array of integer);
>
> Defines a procedure that accepts an open array: an array of integers,
> but without length. It accepts types as
>
> type
> SmallArray = array[1..100] of integer;
> LargeArray = array[1..10000] of integer;
>
> And a constant array (and a dynamic array, if I'm correct) as well.
>
> I'll see if I can add something about it in the docs.
Hopefully Google will pick this up as a guide for the perplexed :-)
So if I understand things correctly, the important point here is that
while it is good practice to do e.g.
type dbgArray3= array[0..2] of integer;
procedure clrDebug3(da: dbgArray3);
rather than
procedure clrDebug3(da: array[0..2] of integer);
you quite simply can't do that when there isn't an explicit index range
since your attempt to define an open array is interpreted as a dynamic
array.
--
Mark Morgan Lloyd
markMLl .AT. telemetry.co .DOT. uk
[Opinions above are the author's, not those of his employers or colleagues]
More information about the fpc-pascal
mailing list