Solved

dynamic array

Posted on 2002-04-27
10
324 Views
Last Modified: 2010-05-18
How can I create a dynamic array (from variant ?) of a user defined record ?

Andrew
0
Comment
Question by:andrewyu
10 Comments
 
LVL 27

Expert Comment

by:kretzschmar
ID: 6972947
type
  TRecord = record
              ....
            end;
  TRecArray : Array of TRecord;

var
  ARecArray : TRecArray;

...

     
0
 

Author Comment

by:andrewyu
ID: 6972949
How can I resize or define dimension of ARecArray ?

Andrew
0
 
LVL 22

Expert Comment

by:Mohammed Nasman
ID: 6972991
 SetLength(MyArr,100);
0
 

Author Comment

by:andrewyu
ID: 6973396
Therefore, I can access the array from MyArr[0] to MyArr[99].

However, how can I create a multi-dimension array with SetLength ?

Andrew
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 25

Accepted Solution

by:
Tomas Helgi Johannsson earned 100 total points
ID: 6973488
   Hi!

Add the following to the type declartion :
     TMRecArray = Array of TRecArray;

The variable should be
ARecArray : TMRecArray;

Then to initialize the multidimenisionalarray
like this

procedure TForm1.FormCreate(Sender: TObject);
var
   i,j,max : Integer;
begin
     max := 100
     SetLength(ARecArray,max);
     for j := 0 to max-1 do
     begin
          SetLength(ARecArray[j],max);
     end;
     for i := 0 to max-1 do
         for j := 0 to max-1 do
           ARecArray[i][j].<record field name> := <what ever>;
end;

This example is a 100x100 matrix. If you want to add a dimmension to your array then you just add in the type declaration <a new name of array type> : <the last name of array type> and so on. And the variable to the new name of the array type.
Then in the initalization you should add some code like this

procedure TForm1.FormCreate(Sender: TObject);
var
   i,j...,z,max : Integer;
begin
     max := 100
     SetLength(ARecArray,max);
     for j := 0 to max-1 do
     begin
          SetLength(ARecArray[j],max);
          for k := 0 to max-1 do
          begin
              SetLength(ARecArray[j][k],max);
              for ...
              begin
                  SetLength(ARecArray[j][k]....,max);
              end
          end;
     end;
end;
 
The for loops for each additional dimmension should be like the for k:= - loop.

Just remember to free the memory :)

Regards,
Tomas Helgi
0
 
LVL 1

Expert Comment

by:Moondancer
ID: 6973847
Have you been helped here, or is more needed?
Moondancer - EE Moderator
0
 

Author Comment

by:andrewyu
ID: 6974397
Thank you very much !

Andrew
0
 
LVL 1

Expert Comment

by:Moondancer
ID: 6974821
Thank you, Andrew, for returning and finalizing this.
Moondancer - EE Moderator
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The uses clause is one of those things that just tends to grow and grow. Most of the time this is in the main form, as it's from this form that all others are called. If you have a big application (including many forms), the uses clause in the in…
Introduction The parallel port is a very commonly known port, it was widely used to connect a printer to the PC, if you look at the back of your computer, for those who don't have newer computers, there will be a port with 25 pins and a small print…
Sending a Secure fax is easy with eFax Corporate (http://www.enterprise.efax.com). First, just open a new email message. In the To field, type your recipient's fax number @efaxsend.com. You can even send a secure international fax — just include t…
Many functions in Excel can make decisions. The most simple of these is the IF function: it returns a value depending on whether a condition you describe is true or false. Once you get the hang of using the IF function, you will find it easier to us…

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now