AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi String im Speicher zerstört
Thema durchsuchen
Ansicht
Themen-Optionen

String im Speicher zerstört

Ein Thema von EWeiss · begonnen am 16. Sep 2016 · letzter Beitrag vom 17. Sep 2016
Antwort Antwort
EWeiss
(Gast)

n/a Beiträge
 
#1

String im Speicher zerstört

  Alt 16. Sep 2016, 20:00
Wenn ich mein Fenster schließe von dem aus mein String übergeben wird
zerstört das den String im Speicher obwohl dieser in meiner Variable laut Debugger
vorher schon angekommen ist.

Wie kann ich das verhindern?
Kann doch nicht sein das ich mein Fenster so lange geöffnet lassen muss bis der String verarbeitet wurde.

String wird zerstört
Delphi-Quellcode:
if BrowseForFile.OutPutFile <> 'then
begin
  MainApp.Newfile := BrowseForFile.OutPutFile; // kommt hier an alles IO
  BrowseForFile.DestroyWindow();
  BrowseForFile := nil;
  MainApp.SampleAudioStream(MainApp.Newfile); // Hier dann nur noch Kauderwelsch
end;
String funktioniert
Delphi-Quellcode:
if BrowseForFile.OutPutFile <> 'then
begin
  MainApp.Newfile := BrowseForFile.OutPutFile; // kommt hier an alles IO
  ShowWindow(BrowseForFile.Handle, SW_HIDE);
  MainApp.SampleAudioStream(MainApp.Newfile); // alles IO
end;
  BrowseForFile.DestroyWindow();
  BrowseForFile := nil;

gruss

Geändert von EWeiss (16. Sep 2016 um 20:05 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#2

AW: String im Speicher zerstört

  Alt 16. Sep 2016, 20:38
Datentyp tatsächlich String, oder eventuell nur PChar?

Bei PChar müsstest du einmal konkret in String casten, damit eine Kopie erzeugt wird.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#3

AW: String im Speicher zerstört

  Alt 16. Sep 2016, 20:42
Datentyp tatsächlich String, oder eventuell nur PChar?

Bei PChar müsstest du einmal konkret in String casten, damit eine Kopie erzeugt wird.
PWideChar..
Habe es mit StrPLCopy und StrCopy versucht das gleiche Problem.
Das seltsame ist es tritt sporadisch auf. (zufällig)


EDIT:
Hmm seltsam im Moment gibt es keine Probleme..

gruss

Geändert von EWeiss (16. Sep 2016 um 22:23 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#4

AW: String im Speicher zerstört

  Alt 16. Sep 2016, 22:24
Probiers mal einfach nur mit String(PCharValue) . Dass das Problem nur sporadisch auftritt liegt am Memory Manager. Dem steht es frei den Speicher nicht direkt für andere Sachen zu benutzen. Unter Umständen liegt dein String bis zum Ende des Programms völlig unverändert an seiner initialen Speicherstelle. Aber halt nur unter Umständen. Wahrscheinlicher ist, dass der Speicher recht zeitnah mit neuen Daten gefüllt wird und dein String somit überschrieben ist.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#5

AW: String im Speicher zerstört

  Alt 16. Sep 2016, 22:29
Probiers mal einfach nur mit String(PCharValue) . Dass das Problem nur sporadisch auftritt liegt am Memory Manager. Dem steht es frei den Speicher nicht direkt für andere Sachen zu benutzen. Unter Umständen liegt dein String bis zum Ende des Programms völlig unverändert an seiner initialen Speicherstelle. Aber halt nur unter Umständen. Wahrscheinlicher ist, dass der Speicher recht zeitnah mit neuen Daten gefüllt wird und dein String somit überschrieben ist.
Werde ich mal versuchen
Danke für die Info.

gruss
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: String im Speicher zerstört

  Alt 16. Sep 2016, 23:51
Hallo,
UnicodeString als Typ sollte das Problem auch lösen.
Heiko
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#7

AW: String im Speicher zerstört

  Alt 16. Sep 2016, 23:57
Hallo,
UnicodeString als Typ sollte das Problem auch lösen.
Hat eigentlich nichts mit Unicode (Hab ich ja schon PWideChar) zu tun..
Es kommen falsche werte im PWideChar.. ganz am Schluss erst kann ich einen teil des Pfades lesen der ausgewählt wurde.
Ganz normal in Deutscher Schrift.

Oder ich verstehe jetzt nicht genau was du meinst.

gruss

Geändert von EWeiss (17. Sep 2016 um 00:00 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.586 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: String im Speicher zerstört

  Alt 17. Sep 2016, 06:58
Der Unterschied ist, dass ein Delphi-String (String, UnicodeString, AnsiString) referenzgezählt ist, P*Char aber nicht. Irgendwo in deinem Quelltext hast du einen String, den du in dem PWideChar hast. Das ist nur ein Pointer auf diesen String.
Heißt: Sobald der ursprüngliche String zerstört wird, ist der Pointer kaputt.

Was du machen kannst: Solange wie möglich mit String arbeiten und erst bei der Übergabe an eine Schnittstelle auf PChar gehen, damit dann der Aufrufer selbst den String noch hat. Oder selbst Speicher für den PChar reservieren und nicht casten, sondern den String dorthin kopieren.
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#9

AW: String im Speicher zerstört

  Alt 17. Sep 2016, 14:16
Ich habe es mal auf UnicodeString geändert.
Muss jetzt mal beobachten ob das Problem nochmals auftritt.

Danke.

gruss
  Mit Zitat antworten Zitat
Antwort Antwort


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 02:04 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