AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TStringList initialisieren! Wie?

Ein Thema von Deltachaos · begonnen am 2. Mai 2009 · letzter Beitrag vom 2. Mai 2009
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Deltachaos
Deltachaos

Registriert seit: 20. Feb 2008
Ort: Berlin
195 Beiträge
 
Delphi 7 Personal
 
#1

TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 12:38
Ich bekomme vom Compiler die Warnung:

Code:
[Warnung] Unit1.pas(254): Variable 'pub' ist möglicherweise nicht initialisiert worden
Es funktionirt ja auch so nur ich möchte eigentlich keine Warnungen haben.
Wie initialisiere ich den eine TStringList?
Geht das nicht mit pub := TStringList.Create; ?


Delphi-Quellcode:
procedure delphi_versionadd(ort, key: string);
var regist: TRegistry;
    pub: TStringList;
    pubdir, pubbrc32, pubbrcc32: string;
    pubi: integer;
begin
  regist := TRegistry.Create;
  try
    regist.RootKey := HKEY_LOCAL_MACHINE;
    pub := TStringList.Create;
    regist.OpenKey(ort, false);
    regist.GetKeyNames(pub);
    regist.CloseKey;
    if pub.count > 0 then
    begin
      for pubi := 0 to pub.count - 1 do
      begin
        regist.OpenKeyReadOnly(ort + '\' + pub[pubi]);
        if regist.ValueExists(key) then
        begin
          pubdir := regist.ReadString(key);
          regist.CloseKey;
          pubdir := IncludeTrailingPathDelimiter(pubdir) + 'Bin\';
          if FileExists(pubdir + 'brc32.exe') then
            pubbrc32 := pubdir + 'brc32.exe';
          if FileExists(pubdir + 'brcc32.exe') then
            pubbrcc32 := pubdir + 'brcc32.exe';
          additem(pub[pubi], pubbrc32, pubbrcc32);
        end;
      end;
    end;
  finally
    regist.free;
    pub.Free;
  end;
end;
Maximilian Ruta
Ich weiß mein Deutsch ist ! Bei Fragen: ich bin fast immer im Mumble
Server: cubexsports.de
Port: 64738
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 12:39
Erzeug die StringListe ausserhalb des try-finally-Blocks.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker
Online

Registriert seit: 14. Aug 2005
1.858 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 12:46
Hallo Deltachaos,


Delphi-Quellcode:
finally
  regist.free;
  pub.Free;
end;
besser:

Delphi-Quellcode:
finally
  pub.Free;
  regist.free;
end;
FIVO-Prinzip!

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.136 Beiträge
 
Delphi 12 Athens
 
#4

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 12:49
wie Luckie schon sagte:
Delphi-Quellcode:
regist := TRegistry.Create;
try
  pub := TStringList.Create;
  try
    ...
  finally
    pub.Free;
  end;
finally
  regist.free;
end;
oder notfalls auch sowas:
Delphi-Quellcode:
pub := nil;
regist := TRegistry.Create;
try
  ...
  pub := TStringList.Create;
  ...
finally
  {if Assigned(pub) then} pub.Free;
  regist.free;
end;
[edit]
ach stimmt ja ... nja, zumindestens wenn man mal etwas nimmt, was nicht auf NIL prüft, dann halt selber prüfen
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#5

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 12:51
Free prüft doch schon auf nil, insofern kannst du dir das Assigned sparen.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.004 Beiträge
 
Delphi 2009 Professional
 
#6

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 13:42
Zitat von Apollonius:
Free prüft doch schon auf nil, insofern kannst du dir das Assigned sparen.
Die Exception könnte schon vor der Erzeugung aufgetreten sein. Dann wäre Pub im finally noch nil.
Michael Justin
habarisoft.com
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 13:46
Schlag mal TObject.Free in System.pas auf.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.136 Beiträge
 
Delphi 12 Athens
 
#8

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 13:54
Zitat von mjustin:
Die Exception könnte schon vor der Erzeugung aufgetreten sein. Dann wäre Pub im finally noch nil.
drumm muß es vor dem Try-Finally auf NIL gesetzt (also initialisiert) werden.
Dabei ist es jetzt egal ob selbst mit Assigned geprüft wird oder ob es .Free selber nochmal macht ... wenn der Objektteiger dort sonstwohin zeigt, würde es (nochmal) knallen oder schlimmer noch, er zeigt zufällig auf ein anderes existierendes Object, dann würdes dieses freigegeben und es knallt plötzlich anderswo und man weiß nicht warum.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von Deltachaos
Deltachaos

Registriert seit: 20. Feb 2008
Ort: Berlin
195 Beiträge
 
Delphi 7 Personal
 
#9

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 15:05
danke.
Ich hab das

pub := TStringList.Create; nun vor

try geschrieben

Delphi-Quellcode:
procedure delphi_versionadd(ort, key: string);
var regist: TRegistry;
    pub: TStringList;
    pubdir, pubbrc32, pubbrcc32: string;
    pubi: integer;
begin
  regist := TRegistry.Create;
  pub := TStringList.Create;
  try
    regist.RootKey := HKEY_LOCAL_MACHINE;
    regist.OpenKey(ort, false);
    regist.GetKeyNames(pub);
    regist.CloseKey;
    if pub.count > 0 then
    begin
      for pubi := 0 to pub.count - 1 do
      begin
        regist.OpenKeyReadOnly(ort + '\' + pub[pubi]);
        if regist.ValueExists(key) then
        begin
          pubdir := regist.ReadString(key);
          regist.CloseKey;
          pubdir := IncludeTrailingPathDelimiter(pubdir) + 'Bin\';
          if FileExists(pubdir + 'brc32.exe') then
            pubbrc32 := pubdir + 'brc32.exe';
          if FileExists(pubdir + 'brcc32.exe') then
            pubbrcc32 := pubdir + 'brcc32.exe';
          additem(pub[pubi], pubbrc32, pubbrcc32);
        end;
      end;
    end;
  finally
    regist.free;
  end;
end;
Maximilian Ruta
Ich weiß mein Deutsch ist ! Bei Fragen: ich bin fast immer im Mumble
Server: cubexsports.de
Port: 64738
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#10

Re: TStringList initialisieren! Wie?

  Alt 2. Mai 2009, 15:24
wo ist jetzt aber dein pub.free?
Korrekt wäre es (wie bereits erwähnt) so:
Delphi-Quellcode:
object1 := TObject1.Create();
try
  object2 := TObject2.Create();
  try
    //do something with object2 and object1
  finally
    object2.Free;
  end;
finally
  object1.Free;
end;
von folgendem würde ich abraten:
Delphi-Quellcode:
object1 := TObject1.Create();
object2 := TObject2.Create();
try
  //do something with object2 and object1
finally
  object1.Free;
  object2.Free;
end;
Denn wenn bei TObject2.Create() ein Fehler auftritt wird Object1 nicht frei gegeben obwohl da beim instanzieren kein Fehler aufgetreten ist.
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:02 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