Elina: Danke für deine Antwort. Es gibt einige Notizen am unteren Rand dieses MSDN-Dokuments (msdn. microsoften-uslibraryhellip), die vor potenziellen Deadlocks warnen, wenn Sie das Ende der beiden umgeleiteten Stdout - und Stderr-Streams synchron lesen. Es ist schwer zu sagen, ob Ihre Lösung anfällig für dieses Problem ist. Auch scheint es, dass Sie den Prozess39 stdoutstderr Ausgang rechts zurück als Eingang senden. Warum. ) Ndash Matthew Piatt Dies ist eine moderne, TPL-basierte Lösung (Task Parallel Library, TPL) basierte Lösung für 4.5 und höher. Antwort # 2 am: Juli 12, 2010, 07:10:13 am »Ich Sache, dass dies ist einfach und besser Ansatz (wir brauchen nicht AutoResetEvent): Antwort # 2 am: Mai 12, 2010, 10:12:13 pm» True, aber shouldn39t Sie tun. FileName Pfad quotggsci. exequot lt Obeycommand. txtquot, um Ihren Code zu zu vereinfachen Oder vielleicht etwas gleichbedeutend mit quotecho Befehl quotieren Pfad quotggsci. exequot, wenn Sie wirklich don39t eine separate obeycommand. txt-Datei verwenden möchten. Ndash Amit Naidu Ihre Lösung braucht nicht AutoResetEvent aber Sie Umfrage. Wenn Sie anstelle der Verwendung von Ereignis (wenn sie verfügbar sind) abstimmen, dann verwenden Sie CPU ohne Grund und dass Sie sind ein schlechter Programmierer. Ihre Lösung ist wirklich schlecht, wenn die anderen mit AutoResetEvent verglichen werden. (Aber ich habe dir nicht gegeben, weil du versucht hast zu helfen). Ndash Eric Ouellet Ich war mit dem gleichen Problem, aber der Grund war anders. Es würde jedoch unter Windows 8, aber nicht unter Windows 7 auftreten. Die folgende Zeile scheint das Problem verursacht haben. Die Lösung war, NICHT deaktivieren UseShellExecute. Ich erhielt nun ein Shell-Popup-Fenster, das unerwünscht ist, aber viel besser als das Programm wartet auf nichts Besonderes passieren. So fügte ich die folgenden Work-around für das: Jetzt ist das einzige, was mich stört, warum dies geschieht unter Windows 8 an erster Stelle. Ich habe versucht, eine Klasse, die Ihr Problem mit Hilfe von asynchronen Stream zu lösen, indem Sie in Konto Mark Byers, Rob, stevejay Antworten lösen würde. Dabei erkannte ich, dass es einen Fehler im Zusammenhang mit asynchrone Prozess-Ausgabe-Stream zu lesen. Sie können das nicht tun: Sie erhalten System. InvalidOperationException. StandardOut wurde nicht weitergeleitet oder der Prozess hat noch nicht begonnen. Danach müssen Sie die asynchrone Ausgabe starten, die nach dem Start des Prozesses gelesen wird. Führen Sie deshalb eine Racebedingung aus, da der Ausgabestream Daten empfangen kann, bevor Sie ihn auf asynchron setzen. Dann könnten einige Leute sagen, dass Sie nur den Stream vor Ihnen lesen müssen Setzen Sie es auf asynchron. Aber das gleiche Problem tritt auf. Es wird eine Racebedingung zwischen dem synchronen Lesen und dem Setzen des Streams in den asynchronen Modus geben. Es gibt keine Möglichkeit, das sichere asynchrone Lesen eines Ausgabestreams eines Prozesses in der eigentlichen Weise zu erledigen. Process und ProcessStartInfo wurden entworfen. Sie sind wahrscheinlich besser mit asynchronen Lesen wie von anderen Benutzern für Ihren Fall vorgeschlagen. Aber Sie sollten sich bewusst sein, dass Sie aufgrund der Race-Bedingung einige Informationen verpassen konnten. System. Diagnostics. ProcessStartInfoClass Assembly: System. dll-Namespace: System. Diagnostics-Zusammenfassung Gibt einen Satz von Werten an, die beim Starten eines Prozesses verwendet werden. C Syntax: public sealed class ProcessStartInfo Anmerkungen ProcessStartInfo wird zusammen mit der Process-Komponente verwendet. Wenn Sie einen Prozess mit der Process-Klasse starten, haben Sie Zugriff auf Prozessinformationen, die zusätzlich zur Verfügung stehen, wenn Sie an einen laufenden Prozess anhängen. Sie können die ProcessStartInfo-Klasse für eine größere Kontrolle über den Prozess verwenden, den Sie starten. Sie müssen mindestens die ProcessStartInfo. FileName-Eigenschaft festlegen, entweder manuell oder mit dem Konstruktor. Der Dateiname ist eine Anwendung oder ein Dokument. Hier wird ein Dokument als beliebiger Dateityp definiert, der eine offene oder eine standardmäßige Aktion zugeordnet hat. Sie können registrierte Dateitypen und die zugehörigen Anwendungen für Ihren Computer über den Ordneroptionsdialog, der über das Betriebssystem verfügbar ist, anzeigen. Die Schaltfläche Erweitert führt zu einem Dialog, der anzeigt, ob eine offene Aktion zu einem bestimmten registrierten Dateityp gehört. Darüber hinaus können Sie andere Eigenschaften festlegen, die Aktionen definieren, die mit dieser Datei ausgeführt werden sollen. Sie können einen Wert angeben, der für den Typ der Eigenschaft ProcessStartInfo. FileName für die Eigenschaft System. Diagnostics. ProcessStartInfo. Verb (nicht unterstützt für die freigegebene Quell-CLI-Eigenschaft) spezifisch ist. Sie können z. B. für einen Dokumenttyp einen Ausdruck angeben. Darüber hinaus können Sie die Eigenschaften der ProcessStartInfo. Arguments-Eigenschaft als Befehlszeilenargumente angeben, die an die offene Methode der Dateien übergeben werden sollen. Wenn Sie beispielsweise eine Texteditoranwendung in der Eigenschaft ProcessStartInfo. FileName angeben, können Sie die Eigenschaft ProcessStartInfo. Arguments verwenden, um eine Textdatei anzugeben, die vom Editor geöffnet werden soll. Standard-Eingabe ist in der Regel die Tastatur, und Standard-Ausgabe und Fehler sind in der Regel der Monitor-Bildschirm. Sie können jedoch die ProcessStartInfo. RedirectStandardInput verwenden. ProcessStartInfo. RedirectStandardOutput - und ProcessStartInfo. RedirectStandardError - Eigenschaften, um zu bewirken, dass der Prozess Eingaben von einer Datei oder einem anderen Gerät eingibt oder diese zurückgibt. Wenn Sie das Process. StandardInput verwenden. Process. StandardOutput. Oder Process. StandardError-Eigenschaften auf der Process-Komponente, müssen Sie zunächst den entsprechenden Wert auf die ProcessStartInfo-Eigenschaft setzen. Andernfalls wirft das System eine Ausnahme aus, wenn Sie den Stream lesen oder schreiben. Setzen Sie ProcessStartInfo. UseShellExecute, um anzugeben, ob der Prozess mit der Betriebssystem-Shell gestartet werden soll. Sie können den Wert einer beliebigen ProcessStartInfo-Eigenschaft bis zu dem Zeitpunkt ändern, zu dem der Prozess gestartet wird. Nachdem Sie den Prozess gestartet haben, hat die Änderung dieser Werte keine Auswirkung. System. Diagnostics. ProcessStartInfo-Benutzerliste: Standardkonstruktor. Dieser Konstruktor wird von abgeleiteten Klassenkonstruktoren aufgerufen, um den Zustand in diesem Typ zu initialisieren. Initialisiert eine neue Instanz der ProcessStartInfo-Klasse, ohne einen Dateinamen anzugeben, mit dem der Prozess gestartet werden soll. Überladen:.ctor (string fileName) Initialisiert eine neue Instanz der ProcessStartInfo-Klasse und gibt einen Dateinamen wie eine Anwendung oder ein Dokument an, mit dem der Prozess gestartet werden soll. Überladen:.ctor (string fileName, string arguments) Initialisiert eine neue Instanz der ProcessStartInfo-Klasse und gibt einen Anwendungsdateinamen an, mit dem der Prozess gestartet werden soll, sowie einen Satz von Befehlszeilenargumenten, die an die Anwendung übergeben werden. Gest oder legt den Satz von Befehlszeilenargumenten fest, die beim Starten der Anwendung verwendet werden sollen. Ruft Suchpfade für Dateien, Verzeichnisse für temporäre Dateien, anwendungsspezifische Optionen und andere ähnliche Informationen ab. System. Diagnostics. ProcessStartInfo Mitgliedsdetails Überladen ctor 1 Zusammenfassung Initialisiert eine neue Instanz der ProcessStartInfo-Klasse, ohne einen Dateinamen anzugeben, mit dem der Prozess gestartet werden soll. Standardkonstruktor. Dieser Konstruktor wird von abgeleiteten Klassenkonstruktoren aufgerufen, um den Zustand in diesem Typ zu initialisieren. C Syntax: Bemerkungen Sie müssen mindestens die Eigenschaft ProcessStartInfo. FileName festlegen, bevor Sie den Prozess starten. Der Dateiname ist eine Anwendung oder ein Dokument. In diesem Fall wird ein Dokument als beliebiger Dateityp definiert, der eine offene oder eine standardmäßige Aktion zugeordnet hat. Sie können registrierte Dateitypen und die zugehörigen Anwendungen für Ihren Computer über den Ordneroptionsdialog, der über das Betriebssystem verfügbar ist, anzeigen. Die Schaltfläche Erweitert führt zu einem Dialog, der anzeigt, ob eine offene Aktion zu einem bestimmten registrierten Dateityp gehört. Optional können Sie auch andere Eigenschaften festlegen, bevor Sie den Prozess starten. Die System. Diagnostics. ProcessStartInfo. Verb (nicht unterstützt auf der freigegebenen Quell-CLI) - Eigenschaft liefert Aktionen, wie z. B. Drucken, mit der Datei, die in der ProcessStartInfo. FileName-Eigenschaft angegeben wird. Die ProcessStartInfo. Arguments-Eigenschaft bietet eine Möglichkeit, Befehlszeilenargumente an die Datei zu übergeben, wenn das System es öffnet. Overloaded ctor 2 Zusammenfassung Initialisiert eine neue Instanz der ProcessStartInfo-Klasse und gibt einen Dateinamen wie eine Anwendung oder ein Dokument an, mit dem der Prozess gestartet werden soll. C Syntax: Eine Anwendung oder ein Dokument, mit dem ein Prozess gestartet wird. Hinweise Der Dateiname ist eine Anwendung oder ein Dokument. In diesem Fall wird ein Dokument als beliebiger Dateityp definiert, der eine offene oder eine standardmäßige Aktion zugeordnet hat. Sie können registrierte Dateitypen und die zugehörigen Anwendungen für Ihren Computer über den Ordneroptionsdialog, der über das Betriebssystem verfügbar ist, anzeigen. Die Schaltfläche Erweitert führt zu einem Dialog, der anzeigt, ob eine offene Aktion zu einem bestimmten registrierten Dateityp gehört. Sie können die ProcessStartInfo. FileName-Eigenschaft ändern, nachdem Sie diesen Konstruktor aufgerufen haben, bis zu dem Zeitpunkt, zu dem der Prozess gestartet wird. Nachdem Sie den Prozess gestartet haben, hat die Änderung dieser Werte keine Auswirkung. Overloaded ctor 3 Zusammenfassung Initialisiert eine neue Instanz der ProcessStartInfo-Klasse und gibt einen Anwendungsdateinamen an, mit dem der Prozess gestartet werden soll, sowie einen Satz von Befehlszeilenargumenten, die an die Anwendung übergeben werden. C Syntax: Eine Anwendung, mit der ein Prozess gestartet wird. Befehlszeilenargumente, die an die Anwendung übergeben werden, wenn der Prozess gestartet wird. Hinweise Der Dateiname ist eine Anwendung oder ein Dokument. In diesem Fall wird ein Dokument als beliebiger Dateityp definiert, der eine offene oder eine standardmäßige Aktion zugeordnet hat. Sie können registrierte Dateitypen und die zugehörigen Anwendungen für Ihren Computer über den Ordneroptionsdialog, der über das Betriebssystem verfügbar ist, anzeigen. Die Schaltfläche Erweitert führt zu einem Dialog, der anzeigt, ob eine offene Aktion zu einem bestimmten registrierten Dateityp gehört. Sie können die Eigenschaften ProcessStartInfo. FileName oder ProcessStartInfo. Arguments ändern, nachdem Sie diesen Konstruktor aufgerufen haben, bis zu dem Zeitpunkt, zu dem der Prozess gestartet wird. Nachdem Sie den Prozess gestartet haben, hat die Änderung dieser Werte keine Auswirkung. Eigenschaft: Argumente (read-write) Zusammenfassung Gest oder setzt den Satz von Befehlszeilenargumenten, die beim Starten der Anwendung verwendet werden sollen. C Syntax: Eigenschaft: EnvironmentVariables (schreibgeschützt) Summary Suchpfade für Dateien, Verzeichnisse für temporäre Dateien, anwendungsspezifische Optionen und andere ähnliche Informationen werden gesammelt. C-Syntax: Eigenschaft: RedirectStandardError (read-write) Zusammenfassung Ruft einen Wert ab, der angibt, ob die Fehlerausgabe des Prozesses in das Process Instances Process. StandardError-Member geschrieben wird, und ermöglicht es Ihnen, an ein anderes Ziel als den Standardfehlerstrom zu schreiben Bildschirm). Dient zum Schreiben von Fehlerdaten in eine Datei oder ein Protokoll. C Syntax: Bemerkungen Die Process-Komponente kommuniziert mit einem Child-Prozess über eine Pipe. Wenn ein untergeordneter Prozess genug Daten an die Pipe schreibt, um den Puffer zu füllen, wird das Kind blockieren, bis das übergeordnete Element die Daten aus der Pipe liest. Dies kann zu einem Deadlock führen, wenn Ihre Anwendung alle Ausgabe auf Standardfehler und Standardausgabe liest, z. B. unter Verwendung des folgenden C-Codes. In diesem Fall würden sowohl der übergeordnete als auch der untergeordnete Prozess blockiert, da die gefüllte Pipe den unterordneten Prozess am Abschluss verhindert, während der übergeordnete Prozess unbegrenzt darauf wartet, dass der untergeordnete Prozess beendet wird. Dieses Problem kann durch Verschieben der ReadToEnd () vor dem WaitForExit () behoben werden. wie folgt. Ein ähnliches Problem tritt auf, wenn Sie sowohl Standard-Ausgabe und Standard-Fehler umleiten und dann versuchen, beide, zum Beispiel mit dem folgenden C-Code zu lesen. Wenn der untergeordnete Prozess einen Text in einen Standardfehler schreibt, wird er den Prozess blockieren, da der übergeordnete Prozess nicht vom Standardfehler lesen kann, bis er von der Standardausgabe beendet worden ist. Der übergeordnete Prozess wird jedoch nicht von der Standardausgabe gelesen, bis der Prozess beendet ist. Eine empfohlene Lösung für diese Situation besteht darin, zwei Threads zu erstellen, damit Ihre Anwendung die Ausgabe jedes Streams auf einem separaten Thread lesen kann. Eigenschaft: RedirectStandardInput (read-write) Zusammenfassung Ruft einen Wert ab, der angibt, ob die Prozeßbefehleingabe aus dem Process Instances Process. StandardInput-Member gelesen wird, und ermöglicht es Ihnen, von einer anderen Quelle als dem Standard-Eingabestream (in der Regel die Tastatur) zu lesen. Dient zum Lesen von Daten aus einer Datei. C-Syntax: Eigenschaft: RedirectStandardOutput (read-write) Zusammenfassung Ruft einen Wert ab, der angibt, ob die Prozeßausgabe in das Process Instances Process. StandardOutput-Member geschrieben wird, und ermöglicht es Ihnen, an ein anderes Ziel als den Standardausgabestream zu schreiben (in der Regel den Monitor Bildschirm). Dient zum Schreiben von Daten in eine Datei. C Syntax: Bemerkungen Die Process-Komponente kommuniziert mit einem Child-Prozess über eine Pipe. Wenn ein untergeordneter Prozess genug Daten an die Pipe schreibt, um den Puffer zu füllen, wird das Kind blockieren, bis das übergeordnete Element die Daten aus der Pipe liest. Dies kann zu einem Deadlock führen, wenn Ihre Anwendung alle Ausgabe auf Standardfehler und Standardausgabe liest, z. B. unter Verwendung des folgenden C-Codes. In diesem Fall würden sowohl der übergeordnete als auch der untergeordnete Prozess blockiert, da die gefüllte Pipe den unterordneten Prozess am Abschluss verhindert, während der übergeordnete Prozess unbegrenzt darauf wartet, dass der untergeordnete Prozess beendet wird. Dieses Problem kann durch Verschieben der ReadToEnd () vor dem WaitForExit () behoben werden. wie folgt. Ein ähnliches Problem tritt auf, wenn Sie sowohl Standard-Ausgabe und Standard-Fehler umleiten und dann versuchen, beide, zum Beispiel mit dem folgenden C-Code zu lesen. Wenn der untergeordnete Prozess einen beliebigen Text in den Standardfehler schreibt, wird er den Prozess blockieren, da der übergeordnete Prozess nicht vom Standardfehler lesen kann, bis er das Lesen von der Standardausgabe beendet hat. Der übergeordnete Prozess wird jedoch nicht von der Standardausgabe gelesen, bis der Prozess beendet ist. Eine empfohlene Lösung für diese Situation besteht darin, zwei Threads zu erstellen, damit Ihre Anwendung die Ausgabe jedes Streams auf einem separaten Thread lesen kann. Eigenschaft: UseShellExecute (read-write) Zusammenfassung Ruft einen Wert ab, der angibt, ob die Betriebssystem-Shell zum Starten des Prozesses verwendet werden soll, oder legt diesen fest. C Syntax: Bemerkungen Wenn Sie diese Eigenschaft auf false setzen, können Sie Input-, Output - und Fehlerquellen umleiten. Wenn Sie die Betriebssystem-Shell zum Starten von Prozessen verwenden, können Sie jedes Dokument (das ist ein registrierter Dateityp, der einer ausführbaren Datei zugeordnet ist und die eine standardmäßige offene Aktion aufweist) starten und Operationen in der Datei wie dem Drucken ausführen Komponente. Wenn ProcessStartInfo. UseShellExecute false ist. Können Sie nur ausführbare Dateien mit der Process-Komponente starten. Eigenschaft: WorkingDirectory (read-write) Zusammenfassung Ruft das Anfangsverzeichnis für den zu startenden Prozess ab oder legt diesen fest. C Syntax: Bemerkungen Wenn das Verzeichnis bereits Bestandteil der Systempfadvariablen ist, ist es nicht notwendig, den Verzeichnisstandort in dieser Eigenschaft zu wiederholen.
No comments:
Post a Comment