Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi TList Zugriffsverletzung ... (https://www.delphipraxis.net/31566-tlist-zugriffsverletzung.html)

Alexander 11. Okt 2004 11:46


TList Zugriffsverletzung ...
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo,
ich bin gerade dabei eine kleine Komponente zu basteln, die mehrere Funktionen verschiedener Art anzeigt (also nur das anzeigen, nicht das ausrechnen der Funktionswerte, zumindest vorerst nicht...).
Ich habe mir eine kleine Klasse für eine einzelne Funktion und eine Klasse für eine Liste von Funktionenen gebastelt, beim Zeichnen der Funktionen kann ich so recht einfach durch alle Funktionen per Schleife wandern.
Doch kommt es leider zu einer Zugriffsverletzung und ich bin gerade nicht in der Lage die zu finden. Könnt ihr mir kurz helfen?
Entweder ist etwas in der PlotterTypes oder in der Procedure paintFunctions() (Unit Plotter) falsch.
Meistens sieht eine zweite (oder dritte, vierte etc :mrgreen:) mehr als eine einzelne Person..

Ehrlich gesagt bin ich mir auch gar nicht mehr so sicher, dass ich das mit den Listen richtig gemacht habe, da ich da vorher noch nicht viel mit gemacht habe...

Vielen Dank schon einmal.
PS: Ich hänge die derzeitige Komponente mal an...

shmia 11. Okt 2004 12:23

Re: TList Zugriffsverletzung ...
 
Deine Destruktoren sind falsch gebaut. Hier ein Beispiel:
Delphi-Quellcode:
destructor TFunction.destroy();
var
  aPoint : ^TPoint;
  i : Integer;
begin
  // Zuerst die eingebetteten Objekte freigeben
  // Alle wieder freigeben...
  for i:=FPoints.Count-1 to 0 do  // in umgekehrter Reihenfolge
  begin
    aPoint := FPoints.Items[i];
    Dispose(aPoint);
    FPoints.Delete(i);
  end;
  FPoints.Free; // FreeAndNil wäre hier überflüssig

  inherited destroy; // dies muss die letzte Zeile sein !!!
end;

Alexander 11. Okt 2004 16:02

Re: TList Zugriffsverletzung ...
 
Danke! Da muss aber dennoch irgendwo noch mindestens ein Fehler drin sein ;-). Denn daran liegt es nicht, der Fehler tritt immer noch auf (beim Aufruf der Procedure paintFunction()).
Kannst du mir weiterhelfen?

Alexander 15. Okt 2004 07:33

Re: TList Zugriffsverletzung ...
 
Hat da keiner ne Idee ? ;-)

kiar 15. Okt 2004 08:16

Re: TList Zugriffsverletzung ...
 
hallo alex,
Delphi-Quellcode:
for i:=FPoints.Count-1 to 0 do
wenn umgekehrt dann so
Delphi-Quellcode:
for i:=FPoints.Count-1 downto 0 do
raik

Alexander 15. Okt 2004 09:33

Re: TList Zugriffsverletzung ...
 
*patsch*
Mal kuggen, ob es noch ein Fehler gibt :roll:

Aber ich denke, da muss noch ein Fehler drin sein, sonst würde es ja nicht in der Methode paintFunction zu ner zugriffsverletzung kommen...

scp 15. Okt 2004 10:22

Re: TList Zugriffsverletzung ...
 
Der Hauptfehler liegt bei TFunctionList.getFunction(). Dann würde ich noch statt ^TFunction ein PFunction definieren:
Delphi-Quellcode:
type
  //...
  PFunction = ^TFunction;
  TFunction = class(TObject)
  private
  //...
Delphi-Quellcode:
function TFunctionList.getFunction(i : Integer) : TFunction;
var
  aFunction : PFunction;
begin
  aFunction := FFunctions.Items[i];
  result := aFunction^;
end;

Desweiteren würde ich noch addFunction() ändern um Konflikte zu vermeiden, wobei sich Destroy und deleteFunction() dann auch ändert:
Delphi-Quellcode:
destructor TFunctionList.destroy();
var
  aFunction : PFunction;
  i : Integer;
begin
  inherited destroy;
  // Alle wieder freigeben...
  for i:=0 to FFunctions.Count-1 do
  begin
    aFunction := FFunctions.Items[i];
    aFunction^.Destroy; // Funktion freigeben
    Dispose(aFunction);
    FFunctions.Delete(i);
  end;
  FreeAndNil(FFunctions);
end;

function TFunctionList.addFunction: TFunction;
var
  aFunction : PFunction;
begin
  New(aFunction);
  with aFunction^ do
  begin
    aFunction^ := TFunction.Create; // Funktion erstellen
  end;
  FFunctions.Add(aFunction);
  result := aFunction^;
end;

procedure TFunctionList.deleteFunction(Value: Integer);
var
  aFunction : PFunction;
begin
  aFunction := FFunctions.Items[Value];
  aFunction^.Destroy; // Funktion freigeben
  Dispose(aFunction);
  FFunctions.Delete(value);
end;
Desweiteren solltest du noch bei TFunction und TFunctionList den Destroy mit override deklarieren.

Alexander 16. Okt 2004 13:57

Re: TList Zugriffsverletzung ...
 
OK. Vielen Dank. Ich werde es mir gleich mal anschauen.

SirThornberry 16. Okt 2004 14:49

Re: TList Zugriffsverletzung ...
 
Zitat:

Delphi-Quellcode:
type
  //...
  PFunction = ^TFunction;
  TFunction = class(TObject)
  private
  //...

Das ist doch schwachsinn (sorry für die Ausdrucksweise). Eine Klasse ist bereits ein Pointer und somit wäre PFunction ein Pointer auf einen Pointer. Man kann doch gleich TFunction nehmen für die TList.

Dementsprechend würden die AddMethoden dann so aussehen
Delphi-Quellcode:
procedure TFunctionList.addFunction(Value: TFunction);
begin
  FFunctions.Add(Value);
end;

procedure TFunctionList.deleteFunction(Value: Integer);
begin
  FFunctions.Delete(value);
end;
Zum nächsten:
Delphi-Quellcode:
  for i:=FPoints.Count-1 to 0 do  // in umgekehrter Reihenfolge
  begin
    aPoint := FPoints.Items[i];
    Dispose(aPoint);
    FPoints.Delete(i);
  end;
  FPoints.Free; // FreeAndNil wäre hier überflüssig
die Zeile "FPoints.Delete(i)" kann auch weggelassen werden da nach der Schleife sowieso "FPoints.Free" aufgerufen wird (für was die Items löschen wenn Sie durch Free dann auch gelöscht werden)


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:35 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz