![]() |
Re: S: Hilfe bei Turbo Pascal
THX @ Ghostwalker & maximov
Das sind beides Ansätze dir mir ganz gut erscheinen, allerdings ist mir maximov's Ansatz doch etwas zu tief in die Materie :) und Ghostwalker's verkettete Liste zwar schön, aber ich glaube für mein Programm doch nicht so ganz passend. Ich hab jetzt einfaches ein statisches Array mit einer Maximalgröße genommen, entweder der Prof. erkennt es an oder eben nicht... so far cook |
Re: S: Hilfe bei Turbo Pascal
Ich arbeite auch zur Zeit mit TB 7.0 und brauche genau das gleiche.
Der CODE von maximov sah interessant aus. Kann mir jemand erklären wie das funktioniert? Und wofür braucht man count? |
Re: S: Hilfe bei Turbo Pascal
Hallo,
naja - count ist die dynamische anzahl der einträge in deinem array, welche du selbst festlegen musst. Also für count irgendeine integer variable einsetzen. Und zur funktionsweise: Ein array ist nix weiter als ein speicherbereich, für den der compiler eine festgelegte lineare datenstruktur voraussetzt. Und genau diese voraussetzung definieren wir mit:
Delphi-Quellcode:
nur das wir eben den speicher nicht von delphi reservieren lassen, sondern dies selbst tun wollen. Dafür dann der pointer-typ. Das das array grösser als werden kann, als die definierte länge, ist egal da bei höheren indizes der speicher einfach weiterhin linear addressiert wird. Wichtig ist nur, das dort dann von uns selbst reservierter speicher vorhanden ist:
Type
PArray = ^TArray; TArray = array[0..0] of integer;
Delphi-Quellcode:
also holen wir speicher von der gewünschten elementen-anzahl (count) * datengrösse der elemente (in diesem fall integer). Nu ist das array benutzbar:
var dynArrPtr:pArray
... getMem(pointer(dynArrPtr), count*sizeOf(integer)); // array auf speicher mappen
Delphi-Quellcode:
Man muss sich halt nur merkeen wie gross das array ist :)
//zugriff wie gehabt //
dynArrPtr^[42] := 1 + 2; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:52 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz