Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Prism PChar und string (https://www.delphipraxis.net/53680-pchar-und-string.html)

tomaten 21. Sep 2005 10:45


PChar und string
 
Hallo, warum funtioniert unter Delphi.NET PChar(string) nicht mehr? Was muss ich tun? Ich brauche das, weil ich eine alte Win32 DLL verwenden muss die als Parameter PChar benötigt. :(

KLS 21. Sep 2005 11:17

Re: PChar und string
 
Mit .net kenn ich mich auch net aus. aber versuchs mal mit @string[1] (nix anderes macht pchar())

jbg 21. Sep 2005 11:47

Re: PChar und string
 
PChar ist ein Zeiger und unter .NET nutzt man keine Zeiger mehr (außer in unsafe Code und der ist recht selten).

Für was brauchst du denn den PChar? Das lässt sich sicherlich anders regeln.

Speedmaster 21. Sep 2005 12:08

Re: PChar und string
 
Mach mal einen Punkt hinter deinen String, du wirst überrascht sein was es alles gibt!

tomaten 21. Sep 2005 12:30

Re: PChar und string
 
Zitat:

Zitat von Speedmaster
Mach mal einen Punkt hinter deinen String, du wirst überrascht sein was es alles gibt!

Das kenn ich, programmiere ja jetzt viel in C#, aber das geht ja überhaupt nicht mit dieser DLL. Deshalb benutz ich hier unsafe Delphi-Code, da geht es unter Win32 schon.

Zitat:

Zitat von jbg
PChar ist ein Zeiger und unter .NET nutzt man keine Zeiger mehr (außer in unsafe Code und der ist recht selten).

Für was brauchst du denn den PChar? Das lässt sich sicherlich anders regeln.

In dem Fall muss ich aber unsafe benutzen, um von .NET auf die Win32 DLL zu kommen!

tomaten 21. Sep 2005 12:39

Re: PChar und string
 
Zitat:

Zitat von KLS
Mit .net kenn ich mich auch net aus. aber versuchs mal mit @string[1] (nix anderes macht pchar())

"unsafe code '@ operator'" obwohl die Function als "unsafe" gekennzeichnet ist! Delphi.NET treibt einen schon ein bisschen in den Wahnsinn! :(

Speedmaster 21. Sep 2005 12:45

Re: PChar und string
 
Zitat:

Zitat von tomaten
Zitat:

Zitat von KLS
Mit .net kenn ich mich auch net aus. aber versuchs mal mit @string[1] (nix anderes macht pchar())

"unsafe code '@ operator'" obwohl die Function als "unsafe" gekennzeichnet ist! Delphi.NET treibt einen schon ein bisschen in den Wahnsinn! :(

function Blabla:Blubb; unsafe;

Dann musst du noch den Compilerschalter "Unsafecode Compileren" anmachen!

tomaten 21. Sep 2005 12:53

Re: PChar und string
 
Ja hab ich doch, ist ja auch nur ne Warnung. Mit Function(@'dkshskhf'[1]) geht es auch, aber mit Function(@stringvar[1]) bekommen ich

"[Error] your.pas(97): E2354 String element cannot be passed to var parameter"

obwohl Function(varname: PChar) nix mit var parameter definiert hat! Das treibt mich echt in den Wahnsinn!

jbg 21. Sep 2005 13:24

Re: PChar und string
 
Zitat:

Zitat von tomaten
Das treibt mich echt in den Wahnsinn!

Und was mich zum Wahnsinn treibt ist, dass jemand .NET einsetzen will, aber immernoch auf Zeigern behart. Wer .NET verwendet, sollte keine Zeiger mehr nutzen. Ansonsten kann er gleich bei der nativen Programmierung bleiben. .NET ist dafür da, dass man ohne Zeiger programmieren kann und nicht mit.

Ich bin mir sicher, dass man den Code auch anders, ohne Zeiger implementieren kann. Selbst die Borland.Vcl.Windows.pas nutzt keine PChars mehr sonden nur noch string, die vom Marshaller dann automatisch beim Aufruf richtig konvertiert werden.

Wenn du Zeiger unbedingt in .NET haben willst, dann kompiliere die Unit in eine DLL und binde sie über P/Invoke in .NET ein.

tomaten 21. Sep 2005 14:29

Re: PChar und string
 
Was mich am meisten nervt ist, wenn Leute labern, aber nicht lesen, warum das so ist! Nochmal für Dich:

ICH MUSS EIN WIN32.DLL EINBINDEN FÜR DIE ES KEINE ALTERNATIVE GIBT, WEDER IN WIN32, NOCH IN .NET! GAR KEINE!

Aber ich muss mich auch nicht erklären, es reicht doch, wenn ich sage, dass ich ein Win32.dll einbinden muss, die nunmal als Parameter PChar erwartet (VB-DLL :( ) ! Oder erzähl Du mir doch, wie ich ASP.NET als Win32 baue, oder einen Win32 Modul in DotNetNuke bekomme! Es gibt für alles einen Grund, akzeptier es einfach!


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:54 Uhr.
Seite 1 von 3  1 23      

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