Standardoutput Readtoend Waitforexit
Elina: Grazie per la risposta. Ci sono alcune note in fondo questo documento MSDN (msdn. microsoften-uslibraryhellip) che mettere in guardia sui potenziali deadlock se si legge alla fine di entrambi stdout e stderr ruscelli sincrono. It39s difficile dire se la soluzione è suscettibile di questo problema. Inoltre, sembra che si sta inviando l'uscita stdoutstderr processo39 terzino destro come input. Perché. ) Ndash Matthew Piatt 26-set-16 a 4:42 Questa è una awaitable più moderno, Task Parallel Library (TPL) soluzione basata per 4.5 e superiori. Esempio di utilizzo Attuazione risposto 5 16 ottobre alle 10:54 ho cosa che questo è semplice e l'approccio migliore (Non abbiamo bisogno AutoResetEvent): risposto 14 Giugno 12 in 14:29 Vero, ma shouldn39t essere fai. FileName Percorso quotggsci. exequot quot lt obeycommand. txtquot per semplificare il codice troppo O forse qualcosa di equivalente a quotecho comando quot Percorso quotggsci. exequot se davvero don39t desidera utilizzare un file obeycommand. txt separato. ndash Amit Naidu 4 giugno 13 alle 22:03 La soluzione non ha bisogno AutoResetEvent ma sondaggio. Quando si esegue sondaggio invece di utilizzare evento (quando sono disponibili), quindi si utilizza CPU senza motivo e che indica che sei un programmatore male. La soluzione è davvero male se confrontato con l'altro utilizzando AutoResetEvent. (Ma io non do -1 perché si è tentato di aiutare). ndash Eric Ouellet 7 nov 14 alle 18:38 mi stava avendo lo stesso problema, ma il motivo era diverso. Sarebbe tuttavia accadere in Windows 8, ma non sotto Windows 7. La seguente riga sembra aver causato il problema. La soluzione era quella di non disabilitare UseShellExecute. Ho ricevuto ora una finestra di popup Shell, che è indesiderato, ma molto meglio rispetto al programma in attesa di nulla di particolare per accadere. Così ho aggiunto il seguente work-around per questo: Ora l'unica cosa che mi dà fastidio è il motivo per cui questo accade in Windows 8, in primo luogo. risposto 13 Gennaio 15 alla 10:35 Ho provato a fare una classe che avrebbe risolto il problema utilizzando asincrono flusso di lettura, prendendo in considerazione Mark Byers, Rob, risposte stevejay. In questo modo mi sono reso conto che c'è un bug relativo al processo asincrono flusso di output di lettura. Non puoi farlo: Riceverete System. InvalidOperationException. StandardOut non è stato reindirizzato o il hasnt processo avviato ancora. Poi si deve avviare l'uscita asincrono leggere dopo il processo è iniziato: In questo modo, fare una condizione di competizione, perché il flusso di uscita in grado di ricevere i dati prima di impostare a asincrona: Poi alcune persone potrebbero dire che basta leggere il flusso prima di impostarlo asincrona. Ma lo stesso problema si verifica. Ci sarà una condizione di competizione tra il sincrono letto e impostato il flusso in modalità asincrona. Non vi è alcun modo per acheive sicura lettura asincrono di un flusso di output di un processo nel processo reale strada e ProcessStartInfo è stato progettato. Probabilmente si sta meglio utilizzando lettura asincrono come suggerito da altri utenti per il vostro caso. Ma si deve essere consapevoli che si potrebbe perdere un po 'di informazioni a causa di razza condition. System. Diagnostics. Process: reindirizzare StandardInput, StandardOutput, StandardError 82.218.217 InputAndOutputToEnd: un modo pratico per utilizzare inputoutputerror reindirizzato su un p. 82218217 ltparam name8221p8221gtThe p reindirizzare. Deve avere UseShellExecute insieme a false. ltparamgt stringa 82218217 ltparam name8221StandardInput8221gtThis verrà inviato come input per il p. (Deve essere nulla se non StartInfo. RedirectStandardInput) ltparamgt 82.218.217 ltparam name8221StandardOutput8221gtThe p8217s uscita saranno raccolti in questa stringa ByRef. (Deve essere nulla se non StartInfo. RedirectStandardOutput) ltparamgt 82.218.217 ltparam errore name8221StandardError8221gtThe p8217s saranno raccolti in questa stringa ByRef. (Deve essere nulla se non StartInfo. RedirectStandardError) Funzione ltparamgt 82218217 ltremarksgtThis risolve il problema stallo accennato msdn. microsoften-uslibrarysystem. diagnostics. p.standardoutput. aspxltremarksgt ltRuntimepilerServices. Extension () gt Sub InputAndOutputToEnd (ByVal p Come Diagnostics. Process, ByVal StandardInput As String. ByRef StandardOutput As String. ByRef StandardError As String) Se p è niente allora throw new ArgumentException (8220p deve essere non null8221) 8216 supponga p è iniziata. Ahimè there8217s alcun modo di controllare. Se p. StartInfo. UseShellExecute poi gettare nuova ArgumentException (8220Set StartInfo. UseShellExecute a false8221) Se (p. StartInfo. RedirectStandardInput ltgt (StandardInput IsNot niente)) poi gettare nuova ArgumentException (8220Provide un ingresso non nullo solo quando StartInfo. RedirectStandardInput8221) Se (p. StartInfo. RedirectStandardOutput ltgt (StandardOutput IsNot niente)) poi gettare nuova ArgumentException (8220Provide una uscita non nullo solo quando StartInfo. RedirectStandardOutput8221) Se (p. StartInfo. RedirectStandardError ltgt (StandardError IsNot niente)) poi gettare nuova ArgumentException (8220Provide un errore non nullo solo quando StartInfo. RedirectStandardError8221) Dim OutputData come nuovo InputAndOutputToEndData Dim ErrorData come nuovo InputAndOutputToEndData Se p. StartInfo. RedirectStandardOutput Poi
Comments
Post a Comment