![]() |
frage zu strings+Char
mal was ganz einfaches :
Code:
undzwar ist meine frage der teil
var s:string;
begin s:='hi'; Messagebox(0,@s[1],'info',64) end;
Code:
von der Messagebox.Der Teil muss ja Char sein aber ich hab einen string und was bewirkt das @ wird das dann umgewandelt oder wie ? und wenn ich [1] hinter dem s weglasse kommen komische zeichen in der messagebox was hat das für ne funktion ?
,@s[1],
|
Re: frage zu strings+Char
Moin iLLe,
an der von Dir genannte Stelle erwartet die Funktion die Adresse eines nullterminierten Strings (Typ PChar), da in C Strings i.d.R. intern keine Längenangabe haben, und das Ende eines Strings mit einer binären Null festgestellt wird. Mit dem s[1] wird das erste erste Zeichen des Strings angesprochen, und das @ davor bedeutet, dass der Compiler die Adresse nehmen soll. Gesamt heisst das für den Compiler: Trage die Adresse des ersten Zeichens von s ein. Die Adresse eines Zeichens lässt sich auch als PChar bezeichnen. Eine Stringvariable enthält eigentlich "nur" die Adresse des Strings, so dass @s den Pointer auf die Adresse zurückgibt, und nicht auf den Inhalt, also die Adresse eines Pointers! Das diese Schreibweise (@s[1]) funktioniert liegt übrigens nur daran, dass Borland Stringvariablen intern automatisch nullterminiert. Wäre das nicht der Fall hättest Du mit dieser Variante ein Problem ;-) Die, üblicher Weise verwendeten, Hugestrings bestehen aus einem Referenzzähler (integer), einem Längenfeld (integer), dem Inhalt (char) und einer binäre Null (char), wobei (in Deinem Beispiel) s die Adresse des Inhaltes enthält. Da der Referenzzähler und das Längenfeld vor dem Inhalt liegen, beginnt der Referenzzähler auf der Adresse s-8, und das Längenfeld auf der Adresse s-4. Die Null liegt dann auf s+Inhalt Längenfeld. |
Re: frage zu strings+Char
Ich weiss zwar nicht was nullterminierte strings sind und dden letzten abschnitt hab ich auch solala verstanden aber den rest weiss ich jetzt danke :)
|
Re: frage zu strings+Char
Hallo iLLe,
in Ergänzung und weiteren Erläuterung zum Beitrag von Christian Seehase die Funktion MessageBox erwartet als zweiten Parameter einen Zeiger auf den String. Nach guter alter Manier, hat Delphi aber im Byte Null des Strings das Längenbyte stehen, damit ist Delphi auch kompatibel zu Kurz Strings. Siehe nachfolgende Erläuterung. Damit aber der String korrekt ausgegeben wird, sagst Du einfach "Bitte den String "S" and der Addresse "@" + 1 Byte [1] ausgeben. Zitat:
|
Re: frage zu strings+Char
Hallo iLLe,
bei Null terminierten Strings wird das Ende eines Strings durch eine binäre Null (0) erkannt. bye |
Re: frage zu strings+Char
danke :bouncing4:
|
Re: frage zu strings+Char
Moin Duffy,
Zitat:
An der Stelle, an der ein HugeString das erste Zeichen enthält, befindet sich bei ShortStrings das Längenbyte. Ausserdem werden ShortStrings nicht automatisch null terminiert. |
Re: frage zu strings+Char
Zitat:
Oder täusche ich mich da? |
Re: frage zu strings+Char
Hallo Christian Seehase,
Zitat:
bye |
Re: frage zu strings+Char
Moin Chewie,
nein, denn der Inhalt beginnt ja bei Offset 0, so dass s+0 = Adresse des ersten Zeichens des Inhaltes. Du hast hier offensichtlich die Indizes und die Offsets verwechselt ;-) @Duffy: Ich wollte eigentlich darauf hinaus, dass Delphi bei HugeStrings eben nicht "nach guter alter Manier" ein Längenbyte verwendet. Das gilt nur für die ShortStrings. Das folgende kann man mit einem HugeString gar nicht machen,
Delphi-Quellcode:
da der Compiler das schon nicht zulässt.
var
sShort : string[10]; begin sShort := '01234'; ShowMessage(IntToStr(ord(sShort[0]))); end; Bei HugeStrings müsste man das so machen:
Delphi-Quellcode:
um direkt an den Längenzähler heranzukommen.
var
sHuge : string; begin sHuge := '01234'; ShowMessage(IntToStr(PInteger(PChar(sHuge)-4)^)); end; Das wiederum liesse sich bei ShortStrings so ähnlich machen
Delphi-Quellcode:
var
sShort : string[10]; begin sShort := '01234'; ShowMessage(IntToStr(PByte(PChar(@sShort))^)); end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:39 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