![]() |
EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zeile'
Liste der Anhänge anzeigen (Anzahl: 1)
Hi,
ich habe hier mal eine solche EOutOfResources-Exception, welche imo durch einen RichEdit-internen Fehler verursacht wird, reduplizierbar gemacht. Was mich daran jetzt u.a. interessieren würde ist, ob diese Exception mittels der folgenden Proc auch überall (also auf jedem PC) erzeugbar ist oder ob sich deren Auftauchen event. auch irgendwie noch etwas system- bzw. umgebungsabhängig verhält. Hier also der Exception-Erzeugungs-Code (nötig dazu: 1*RichEdit, 1*Button, 2*Labels):
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var I : integer; AStr : String; begin RichEdit1.Perform(EM_SetLimitText,$7ffffffe,0); // ist aber unnötig, da Text < 64KB with RichEdit1 do begin RichEdit1.Clear; AStr := '---------------------'; RichEdit1.Lines.Add(AStr + '--------------'); for I := 1 to 2440 do RichEdit1.Lines.Add(AStr); Lines.Insert(0,'on: ' + '00:00:00 '); Lines.Insert(2,'on: ' + DateToStr(Now) + ' 00:00'); Lines.Insert(3,'on: ' + DateToStr(Now) + ' 24:00 00:00:00'); SelStart := Perform(EM_LINEINDEX,3,0) + 37; // = Position des '00' in Zeile3 SelLength := 2; SelText := '24'; // Austausch der ersten '00' durch ein '24' Label1.Caption := 'Chars = ' + IntToStr(Length(Lines.Text)); Label2.Caption := 'Lines = ' + IntToStr(Lines.Count); Lines.Add('bla bla'); // <=== hier wird die Exception ausgelöst end; end; Im angehängten Bild befindet sich noch ein kleiner Screen-Shot vom Programm-Output für denjenigen Fall, bei dem die letzte Lines-Add()-Zeile im Code weggelassen wird (also z.B. mit Comment-Slashes davor). Dann tritt zwar keine Exception mehr auf, aber das dann angezeigte Endergebnis ist fehlermäßig auch ziemlich lustig. Event. checken ja ein paar von euch mal kurz, ob diese Exception auf eurem Rechner ebenfalls eintritt. Auf meinem PC ist der Fehler jedenfalls beliebig wiederholbar. Und da der Code in allen Teilen eigentlich auch mehr oder weniger üblich ist, sieht das Ganze meines Erachtens also irgendwie schon nach einer echten Fehlfunktion des RichEdit-Controls aus. Eine, die dann natürlich auch immer und überall mal auf einen lauern könnte ...und wodurch das RichEdit doch auch eigentlich schon irgendwie unbrauchbar würde, oder? Oder irre ich da etwa irgendwo??? Ansonsten bräuchte man für Progs, die man auch irgendwie mal etwas weitergeben möchte, dann doch wohl ein alternatives (fehlerloses) Text-Control. Eines, das zum RichEdit zwar möglichst kompatibel ist (zwecks einfachem Austausch in bisherigen Progs), welches aber auch wieder nicht davon abgeleitet sein sollte? Was ich nicht brauche sind Tipps, mit denen ich den Error nur vordergründig etwas "wegdrücken" kann. Interessant wäre aber, was man gegen eine solche Fehlermöglichkeit prinzipiell tun könnte, um sie mit Sicherheit auszuschließen. Thx im Voraus. PS. Oder sollte man die Exception event. immer mit der Meldung abfangen: "Sorry, kleine Fehlfunktion des RichEdit-Controls, die Schuld dafür suchen Sie bitte bei der Firma Micro-Soft" ? |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Also ich weiß nicht, ob das wirklich ein Fehler von Winzigweich ist. Warum genau benutzt du denn Perform? Kenne diese Funktion jetzt nicht so wirklich von ihrer Benutzung, aber ich denke, dass du hier vielleicht genau den Fehler drin hast, den du nicht möchtest.
Hatte auch mal ein Problem mit EOutOfRessource (bei einer selbsterstellten Tiff-Komponente). Da war es dann wirklich ein Speicherleck, dass zwar gar nicht so hektisch wirkte aber ziemlich schnell alle Systemressourcen verbraten hat (auf nem 3Ghz 64 Bitter, mit 2 GByte Ram, was halt schnelles System aber nicht mehr Systemressourcen bedeutet). Hatte meinen Fehler nur so gut versteckt, dass ich echt ein Weilchen suchen durfte. Also denke ich mal, dass der Fehler nicht allein durch die Zuweisung kommt, denke mal, dass ein Lines.Add schon getestet wurde und sicher funktioniert. Möchte auch nicht sagen, dass du Unrecht hast, sicherlich macht MS genug Fehler (wer nicht?) aber die Wahrscheinlichkeit für unentdeckte Fehler ist halt doch geringer als für Eigene (zumindest bei mir). Gruß Der Unwissende |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Hallo,
der Fehler ist abhängig vom Betriebssystem bzw. eher von der genutzten riched32.dll, bei XP wird ja darin auf die riched20.dll verlinkt. Unter NT tritt der Fehler nicht auf, dort wird eine ältere riched32.dll genutzt. Sobald man die riched32.dll und riched20.dll aus XP in das Verzeichnis der Anwendung auf den NT-Rechner kopiert, wird auch dann die Exception ausgelöst. Also eine alte riched32.dll ins Anwendungsverzeichnis kopieren, dann ist der Fehler zumindest nicht mehr vorhanden. Dann fehlen Dir aber die Funktionen die riched20 bietet. :? |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Bei mir tritt der Fehler auch auf. Habe etwas im Internet geforscht, anscheinend hat es mit dem Gebrauch von Lines.Add zu tun (Ich weiss allerdings nicht, wo das Problem genau liegt). Es wird ein Workaround beschrieben, der bei mir funktioniert:
Delphi-Quellcode:
SelStart wird von SelText automatisch angepasst und muss nur einmal zu Beginn einer Serie von Anfügungen aufgerufen werden.
// statt Lines.Add:
RichEdit1.SelStart := RichEdit1.GetTextLen; RichEdit1.SelText := ('bla bla bla')+#13#10; Gruß, teebee |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Danke Allen fürs Antworten.
Zitat:
Zitat:
Zitat:
Ich habe jetzt mal beide DLLs hintereinander ins Anwendungsverzeichnis kopiert, die Exception allerdings blieb. Aber selbst wenn es bei einer DLL keine Exception gäbe, wenn man das Prog mal weitergeben wollte, dann müsste man diese Dll wohl immer mit ins Anwendungsverzeichnis mit hineinkopieren? :roll: @teebee Durch das Lines.Add wird die Exception nur ausgelöst. Der dieser zugrunde liegende Fehler wird allerdings schon vorher irgendwie verursacht. Mit deinen Zeilen tritt die Exception bei mir auch nicht mehr auf (auch z.B. mit Lines.Text:=Lines.Text+'bla' nicht), aber der im Bildanhang angezeigte Fehler taucht damit trotzdem noch auf. |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Ich habe Deinen Code so verändert, und das Ergebnis sieht zumindest so aus, als könnte es hinkommen:
Delphi-Quellcode:
Gruß, teebee
with RichEdit1 do begin
RichEdit1.Clear; AStr := '---------------------'; RichEdit1.Lines.Add(AStr + '--------------'); Richedit1.SelStart := RichEdit1.GetTextLen; for I := 1 to 2440 do RichEdit1.SelText := AStr+#13#10; RichEdit1.SelStart := 0; Richedit1.SelText := 'on: ' + '00:00:00 '+#13#10+#13#10; Richedit1.SelText := 'on: ' + DateToStr(Now) + ' 00:00'+#13#10; Richedit1.SelText := 'on: ' + DateToStr(Now) + ' 24:00 00:00:00'+#13#10; SelStart := Perform(EM_LINEINDEX,3,0) + 37; // = Position des '00' in Zeile3 SelLength := 2; SelText := '24'; // Austausch der ersten '00' durch ein '24' Label1.Caption := 'Chars = ' + IntToStr(Length(Lines.Text)); Label2.Caption := 'Lines = ' + IntToStr(Lines.Count); RichEdit1.SelStart := RichEdit1.GetTextLen; RichEdit1.SelText := ('bla bla bla')+#13#10; // Lines.Add('bla bla'); // <=== hier wird die Exception ausgelöst end; |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Hallo,
Zitat:
Der Fehler wird ursächlich ausgelöst durch Insert an Zeile 0. Daher wird auch die '24' an die falsche Stelle geschrieben, nehme an das die eingefügten Zeilen wegen dem Fehler dann nicht mitgerechnet werden(können?). Fügt man eine Zeile tiefer ein dann gibt es keinen Fehler.
Delphi-Quellcode:
was machen ? Nie an Index 0 eine Zeile mit Insert einfügen.
//Lines.Insert(0,'on: ' + '00:00:00 ');
Lines.Insert(1,'on: ' + '00:00:00 '); Lines.Insert(2,'on: ' + DateToStr(Now) + ' 00:00'); Lines.Insert(3,'on: ' + DateToStr(Now) + ' 24:00 00:00:00'); |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Zitat:
Delphi-Quellcode:
...und dann tritt der Fehler eben doch wieder auf. Die Exception zwar nicht, weil du ja keinerlei Lines.Add mehr machst, aber den Output-Fehler gibt's trotzdem.
RichEdit1.SelStart := 0;
Richedit1.SelText := 'on: ' + '00:00:00 '+#13#10; SelStart := Perform(EM_LINEINDEX,2,0); Richedit1.SelText := 'on: ' + DateToStr(Now) + ' 00:00'+#13#10; Richedit1.SelText := 'on: ' + DateToStr(Now) + ' 24:00 00:00:00'+#13#10; Zitat:
Zitat:
|
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Merkwürdigerweise funktioniert alles prima, wenn Du nur bis 2134 gehst. Dann geht auch Lines.Add. Mit einem einfachen Memo geht auch alles gut. Sehr seltsam....
Viel Erfolg noch, teebee |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
@teebee
>> Sehr seltsam.... Echt! Letztlich wird der Grund dafür aber wahrscheinlich schon ein kleiner Fehler in dieser RichEd20.dll sein. Ein Memo wird dessen Funktionen zwar ebenfalls benutzen (oder?), hat aber intern wohl auch eine etwas andere Speicherorganisation (es hat ja z.B. auch nicht diesen internen {\rtf1...-Code zu verwalten). Na ja, eventuell wird ja diese DLL bei irgendeinem nächsten Servic-Pack dann auch mal mit erneuert :stupid:. Thx jedenfalls nochma. |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Hallo,
Zitat:
aber das muss doch von irgendwelchen Bedingungen abhängen, Zeilenanzahl, Zeichenanzahl ... Zitat:
Wenn ich den Code wie folgt abändere, dann gibt es keinen Fehler:
Delphi-Quellcode:
Diese 14 Zeichen ist genau die Länge hinter der '24' die bei einem Fehler verleiben
AStr := '---------------------';
RichEdit1.Lines.Add(AStr + '--------------'+'--------------');//<--------- um 14 Zeichen erweitert for I := 1 to 2440 do RichEdit1.Lines.Add(AStr); Lines.Insert(0,'on: ' + '00:00:00 '); Lines.Insert(2,'on: ' + DateToStr(Now) + ' 00:00'); Lines.Insert(3,'on: ' + DateToStr(Now) + ' 24:00 00:00:00');
Ändere ich nun wiederum die Insert-Index auf :
Delphi-Quellcode:
und füge die '24' entsprechend in Zeile 4 ein, verschiebt sich die 24 an eine andere Stelle.
Lines.Insert(1,'on: ' + '00:00:00 ');
Lines.Insert(3,'on: ' + DateToStr(Now) + ' 00:00'); Lines.Insert(4,'on: ' + DateToStr(Now) + ' 24:00 00:00:00'); Nehme ich nun die Anzahl der Zeichen hinter der '24' und baue sie entsprechend in den Code ein, ist der Fehler wieder beseitigt. Wer Lust hat kann gerne versuchen die Zusammenhänge/Ursache zu finden, ich gebs auf. :wall: Ob es nun an der Dll direkt oder an der Kapselung des RichEdit durch Delphi liegt? kA. Ich werd doch wohl weiterhin die Daten wie gewohnt über einen Stream ins RichEdit schreiben, damit hab ich diese Probleme bisher noch nicht gehabt. |
Re: EOutOfResources: 'Fehler bei Einfügen von RichEdit -Zei
Also, mit einer RichEd20.dll ab der Version 4.0 verschwindet dieser Error übrigens. Normal hat ein W2k-Rechner ja nur eine solche DLL der Version 3.0 in C:\WINNT\system32 ...und womit er also für die oben beschriebene Fehlererscheinung durchaus anfällig ist!
Trotzdem aber: In C:\Programme\Gemeinsame Dateien\Microsoft Shared\Office10 sollte man da auch zusätzlich noch eine Riched20.dll der Version 4.0 vorfinden. Die produziert nicht nur diesen Fehler nicht mehr, sondern ist bei größeren Texten sogar auch noch etwas schneller. Wahrscheinlich wollte MS damit bzgl. der eigenen Office-Anwendungen allen Eventualitäten lieber gleich zuvorkommen. Will man beim Weitergeben einer eigenen Anwendung (die intern mit solchen Befehlskombinationen agiert und bei der theoretisch auch mal so große Texte vorkommen können) dann auf Nummer Sicher gehen, wird einem also nichts anderes übrig bleiben als diese Dll-Version 4.0 im Zielverzeichnis mit zu entpacken. Es wird wohl erlaubt sein, die dann einfach mit weiterzugeben, denn sie ist ja im besagten ...\Microsoft Shared\Office10-Folder des Ziel-PCs sowieso schon vorhanden (...und alternativ/notfalls könnte man sie ja auch von dort einfach ins Zielverzeichnis rüberkopieren). MfG |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:58 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 by Thomas Breitkreuz