![]() |
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. |
AW: Boolean.ToString geht nicht?!
Zitat:
|
AW: Boolean.ToString geht nicht?!
Ja, leider ist dieses ToString etwas pervers
und nicht mit
Delphi-Quellcode:
vergleichbar.
BoolToStr
Im Boolean-Helper gibt es auch zwei Versionen, also einmal von der Variable aus und dann nochmal als Class-Funktion. Und das Gewollte bekommst du nur von der normalen Funktion, in Verbindung mit diesem TUseBoolStrs, sonst springt es auf die Class-Function, bei deinem True, wo die Lösung dann
Delphi-Quellcode:
wäre, oder eben
Boolean.ToString(b, TUseBoolStrs.True)
Delphi-Quellcode:
:freak:
b.ToString(TUseBoolStrs.True)
|
AW: Boolean.ToString geht nicht?!
Zitat:
![]() Bis bald... Thomas |
AW: Boolean.ToString geht nicht?!
Jupp, weil es sonst die beiden gleichnamigen Funktionen / Class-Functions nicht unterscheiden kann, wenn sie den "selben" Parameter-Typ besitzen.
Dieser Scoped-Enum ist aber dahingehend pervers, weil man dessen Namen nicht kennt (ständig vergisst) und die Codevervollständigung ihn dir oft nicht sagen will. Statt "diesem Parameter", entweder unterschiedliche Funktionsnamen für Funktion und Klassenfunktion oder für Nummerisch (0 oder -1) und Namentlich (False oder True). Wobei, wer um Himmels Willen nutzt überhaupt die Class-Functions .... weg mit dem Schrott. (Unterschied siehe #12) Warum gegen eigentlich BoolToStr und ToString -1 aus, obwohl das True vom Delphi-"Boolean" eigentlich als +1 deklariert ist? (nur kleinstes Bit gesetzt) Ja, das TRUE vom C++ im BOOL/LongBool, sowie ByteBool und WordBool, ist als -1 deklariert (alle Bits gesetzt) Aber OK, von der Auswertung her ist es egal, da False = 0 und True = nicht 0. (PS: drum ist
Delphi-Quellcode:
immer eine schlechte Idee)
if B = True then
|
AW: Boolean.ToString geht nicht?!
Delphi-Quellcode:
Oder
var b:Boolean = true;
Showmessage(ord(b).tostring);
Delphi-Quellcode:
Für so typumwandlungen von kleinen ordinalen Typen wie Boolean oder Enums sollten Konnstanten Array und Ord() doch gut sein .
//Evtl reihenfolge umtauschen...habe hier keine IDE zur Hand um das zu prüfen.
Const B2I:Array [Boolean] of Integer = (0,1); B2S:Array [Boolean] of String = ('False, True'); I2B:array [0..1] of Boolean (false, True); |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:15 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