![]() |
Langen String auf der Befehlszeile übergeben?
Hallo! Ich möchte einen String, der länger als 32 KB ist, als Parameter auf der Befehlszeile an ein eigenes Konsolenprogramm übergeben. Meine Versuche haben gezeigt, dass bei ca. 32 KB Schluss ist. Wie kann man also längere Strings auf der Befehlszeile übergeben? (Ich könnte zwar den String in eine temporärer Datei speichern, und dann diesen Dateipfad übergeben, aber besser wäre es, wenn ich den String direkt übergeben könnte).
|
AW: Langen String auf der Befehlszeile übergeben?
Wie du siehst, gibt es für die Übergabe der Parameter eine Maximallänge und daran kannst du auch nichts ändern.
64 KB, also bei Unicode ~32000 Zeichen z.B. siehe CommandLine > CreateProcess Zitat:
![]() |
AW: Langen String auf der Befehlszeile übergeben?
Danke für den Hinweis. Könnte man nicht den String mit PChar in eine nullterminierte Zeichenfolge umwandeln und dann die Adresse dieser Zeichenfolge übergeben? Das Konsolenprogramm würde dann den String an der übergebenen Adresse auslesen.
|
AW: Langen String auf der Befehlszeile übergeben?
Wenn du mit Messages arbeitest und ausserdem die Übergabe auch zur Laufzeit geht, könntest du deinen String mit der Windows Message
![]() |
AW: Langen String auf der Befehlszeile übergeben?
Zitat:
|
AW: Langen String auf der Befehlszeile übergeben?
Ja, man kann ein sog. Message-only-window erstellen - also komplett unsichtbar und eigentlich nur dafür geeignet Messages zu empfangen.
Das mit dem Pointer und "auslesen" ginge über ![]() |
AW: Langen String auf der Befehlszeile übergeben?
Zum Thema IPC gibt es viele Wege.
Einfach wäre z.B. eine Named MMF (Memory-Mapped File) oder eine Pipe und im Parameter wird dann der Name übergeben. |
AW: Langen String auf der Befehlszeile übergeben?
Wie wärs denn, wenn du die Daten zuerst komprimierst?
|
AW: Langen String auf der Befehlszeile übergeben?
Zitat:
|
AW: Langen String auf der Befehlszeile übergeben?
Du kannst die Eingabe in eine Datei speichern und diese Datei dann in das Command-Programm rein pipen. Siehe z.B. hier (command redirection):
![]() |
AW: Langen String auf der Befehlszeile übergeben?
Zitat:
Code:
Falls nur einzelne Parameter ne Größenbegrenzung haben, könntest du sie aufsplitten?!
myprog.exe "Parameter 1" "Parameter 2"
|
AW: Langen String auf der Befehlszeile übergeben?
Alles zusammen, inklusive Pfad und Dateiname der EXE, also die komplette Command-Line.
|
AW: Langen String auf der Befehlszeile übergeben?
Zitat:
![]()
Delphi-Quellcode:
Wie müsste man die Typdeklaration modifizieren, damit auch sehr lange Strings übertragen werden können?
type
TTextData = Packed Record DataInt: Integer; DataBoo: Boolean; DataStr: string[255]; // höchstens 255 Bytes! end; |
AW: Langen String auf der Befehlszeile übergeben?
Mir fällt spontant nichts brauchbares ein..
Eine andere Variante der von dir genannten Methode, die du ja nicht umsetzen willst (ne Datei erzeugen und den Pfad übergeben): du könntest die zweite Anwendunge so umprogrammieren, dass er Datensegmente puffern kann (in ne Zwischendatei) und wenn die Datei dann vollständig ist, mit der eig. Aufgabe beginnt. ~ Anstatt: myapp.exe <32kbstr> Folgendes: myapp.exe <8kbstr> myapp.exe <8kbstr> myapp.exe <8kbstr> myapp.exe <8kbstr> Oder halt noch weiter runter mit den Segmenten. Letzendlich ist es aber dasselbe, soger ne eher hässlichere Variante! |
AW: Langen String auf der Befehlszeile übergeben?
Ein statisches Array[..] of Char oder ein "PChar", wobei man den Inahlt eines Strings/PChar oder wer weis was sonst noch in die MMF kopiert, inkl. der abschließenden #0 und am die MMF als PChar auslesen kann?
Aber natürlich nicht Char/PChar, sondern natürlich AnsiChar/PAnsiChar oder WideChar/PWideChar, da ja prozessübergreifende Daten besser nur aus generischen Typen bestehen sollten, welche sich niemals verändern können. |
AW: Langen String auf der Befehlszeile übergeben?
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:40 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