![]() |
Delphi-Version: 11 Alexandria
Boolean.ToString geht nicht?!
Ich möchte gerne einen Boolean in Stringform anzeigen. Dazu wollte ich BoolVar.ToString nutzen. Leider btingt mir das immer den Zahlenwert, also 0 oder -1. Die Boolean.ToString Helperfunktionen scheinen nicht zu funktionieren. Da läuft irgendwas mit den Default Parametern der Helperklasse und ser Sysutils.BooToStr Funktion ziemlich falsch.
Delphi-Quellcode:
var
b: Boolean; s: String; begin b := True; s := b.ToString; // liefert '-1' s := b.ToString(True); // Liefert '-1', müsste aber 'True' liefern b := False; s := b.ToString; // liefert '0' s := b.ToString(True); // Liefert '-1' ?! Der True Parameter müsste steuern, ob die BooleStr verwendet werden sollen (UseBooleStrs)! |
AW: Boolean.ToString geht nicht?!
Ich nehme immer
Delphi-Quellcode:
, damit bekommst du 0 für False und 1 für True
meinBoolean.ToInteger().ToString()
|
AW: Boolean.ToString geht nicht?!
Hi,
habe das gerade ausprobiert und das gleiche Verhalten wie Rolf. Irgendwie kommt der Compiler mit der überladenen Funktion vom Helper durcheinander. Wenn man der .ToString-Methode True übergibt (ruft BoolToStr auf), interpretiert das die aufgerufene BoolToStr-Methode komischerweise als False. Es funktioniert nur, wenn den gewünschten Parameter TUseBoolStrs.True benutzt wird, obwohl TUseBoolStrs ja auf True oder False verweist, was irgendwie komisch ist.
Delphi-Quellcode:
Die Rückgabe von 0 und -1 ist richtig, siehe Doku:
var
b: Boolean; s: string; begin b := True; s := b.ToString; //-1, richtig s := b.ToString(True); //-1, obwohl 'True' erwartet, siehe Rolfs Kommentar s := b.ToString(TUseBoolStrs.True); //'True', richtig s := BoolToStr(b, True); //'True', richtig end; ![]() Als Alternative kannst du einfach
Delphi-Quellcode:
benutzen.
s := BoolToStr(b, True);
|
AW: Boolean.ToString geht nicht?!
Was funktioniert ist:
Delphi-Quellcode:
hier wird im class helper nicht richtige Funktion verwendet. (zumindest in meinen Beispiel)
s := b.ToString(TUseBoolStrs.True);
True <> TUseBoolStrs.True :gruebel: |
AW: Boolean.ToString geht nicht?!
Ja das mit dem TUseBoolStrs.True habe ich unterdessen auch rausgefunden. Bool.ToString(TUseBoolStrs.True) liefert "True", Bool.ToString(True) liefert "-1".
Hat da wer eine plausible Erklärung für dieses Verhalten und wieso man da unbedingt TUseBoolStrs.True nutzen muss? |
AW: Boolean.ToString geht nicht?!
Liste der Anhänge anzeigen (Anzahl: 1)
Das siehst du doch eigentlich direkt auf den ersten Blick:
Anhang 56721 |
AW: Boolean.ToString geht nicht?!
entfernt - habe mich geirrt
|
AW: Boolean.ToString geht nicht?!
Zitat:
Bei der regulären function gibt es nur den optionalen Parameter für die Darstellung. Problematisch ist hier die Kombination von Overloads und optionalen Parametern gepaart mit der Kollision des zu bearbeitenden Typs (Boolean) und dem erwarteten Parameter für die Darstellung (ebenfalls Boolean). Diese Kollision wurde mit dem neuen Typ TUseBoolStrs umgangen. Leider passt das nicht mehr zur Erwartungshaltung des Entwicklers. Es gibt aber auch Meinungen, dass ein Aufruf einer class function nur über die Angabe des Typs und nicht einer Variablen des Typs gehen dürfte. Ich fürchte nur, dass eine solche Einschränkungen eine Menge Code nicht mehr compilieren ließe. |
AW: Boolean.ToString geht nicht?!
Ok danke für die Erläuterung. Wenn ich da als Anwender den Defaultwert False in der Parmaterliste sehe, komme ich nicht dirket auf die Idee, da TUseBoolStrs.True zu verwenden. Wäre dort der Defaultwert mit TUseBoolStrs.False angezeigt worden, wäre es wohl deutlich klarer gewesen.
|
AW: Boolean.ToString geht nicht?!
Zitat:
Hätten wir einen funktionierenden Bugtracker oder Feedback-System bei Embarcadero, könnte man das sogar dort einreichen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:13 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