Thursday, 26 October 2017

Useshellexecute Waitforexit


Sua solução não precisa de AutoResetEvent, mas você pesquisa. Quando você faz pesquisa em vez de usar o evento (quando eles estão disponíveis), então você está usando CPU sem razão e que indicam que você é um programador ruim. Sua solução é realmente ruim quando comparado com o outro usando AutoResetEvent. (Mas eu não te dei -1 porque você tentou ajudar). Ndash Eric Ouellet Nov 7 14 at 18:38 Eu estava tendo o mesmo problema, mas a razão era diferente. No entanto, aconteceria no Windows 8, mas não no Windows 7. A seguinte linha parece ter causado o problema. A solução era NÃO desativar UseShellExecute. Eu agora recebi uma janela popup Shell, que é indesejável, mas muito melhor do que o programa esperando nada particular acontecer. Então eu adicionei o seguinte work-around para que: Agora, a única coisa que me incomoda é por que isso está acontecendo no Windows 8 em primeiro lugar. Respondido Jan 13 15 at 10:35 Exemplo de uso ImplementationSystem. Diagnostics. Process: redirecionar StandardInput, StandardOutput, StandardError 82218217 InputAndOutputToEnd: uma maneira prática de usar redirecionada entrada / saída / erro em um p. 82218217 ltparam name8221p8221gtP para redirecionar. Deve ter UseShellExecute definido como false. lt/paramgt 82218217 ltparam name8221StandardInput8221gtEssa string será enviada como entrada para o p. (Deve ser Nothing se não StartInfo. RedirectStandardInput) lt / paramgt 82218217 ltparam name8221StandardOutput8221gtA saída p8217s será coletada nesta seqüência ByRef. (Deve ser Nothing se não StartInfo. RedirectStandardOutput) lt / paramgt 82218217 ltparam name8221StandardError8221gtO erro p8217s será coletado nesta string ByRef. (Deve ser Nothing se não StartInfo. RedirectStandardError) lt / paramgt 82218217 ltremarksgt Esta função resolve o problema de deadlock mencionado em msdn. microsoft/en-us/library/system. diagnostics. p.standardoutput. aspxlt/remarksgt ltRuntimepilerServices. Extension () gt Sub InputAndOutputToEnd (ByVal p Como Diagnostics. Process, ByVal StandardInput As String. ByRef StandardOutput As String. ByRef StandardError As String) Se p Is Nothing Then Throw Novo ArgumentException (8220p deve ser non-null8221) 8216 Assumir p iniciou. Infelizmente não há maneira de verificar. Se p. StartInfo. UseShellExecute Em seguida, arremessar New ArgumentException (8220Set StartInfo. UseShellExecute para false8221) Se (p. StartInfo. RedirectStandardInput ltgt (StandardInput IsNot Nothing)) Em seguida, lançar ArgumentException novo (8220Provide uma entrada não nula somente quando StartInfo. RedirectStandardInput8221) If (PStStartInfo. RedirectStandardOutput ltgt (StandardOutput IsNot Nothing)) Em seguida, arremessa New ArgumentException (8220Provide uma saída não nula somente quando StartInfo. RedirectStandardOutput8221) Se (p. StartInfo. RedirectStandardError ltgt (StandardError IsNot Nothing)) Then Throw New ArgumentException (8220Provide Um erro não nulo somente quando StartInfo. RedirectStandardError8221) Dim outputData As New InputAndOutputToEndData Dim errorData As New InputAndOutputToEndData Se p. StartInfo. RedirectStandardOutput ThenSystem. Diagnostics. ProcessStartInfoClass Assembly: System. dll Namespace: System. Diagnostics Resumo Especifica um conjunto de valores usados ​​quando Iniciar um processo. C Sintaxe: public sealed class ProcessStartInfo Comentários ProcessStartInfo é usado em conjunto com o componente Process. Quando você inicia um processo usando a classe Process, você tem acesso a informações de processo além daquelas disponíveis ao anexar a um processo em execução. Você pode usar a classe ProcessStartInfo para maior controle sobre o processo que você iniciar. Você deve pelo menos definir a propriedade ProcessStartInfo. FileName, manualmente ou usando o construtor. O nome do arquivo é qualquer aplicativo ou documento. Aqui, um documento é definido como sendo qualquer tipo de arquivo que tenha uma ação aberta ou padrão associada a ele. Você pode exibir os tipos de arquivos registrados e seus aplicativos associados para o computador usando a caixa de diálogo Opções de pasta disponível no sistema operacional. O botão Avançado leva a uma caixa de diálogo que mostra se há uma ação aberta associada a um tipo de arquivo registrado específico. Além disso, você pode definir outras propriedades que definem ações a serem tomadas com esse arquivo. Você pode especificar um valor específico para o tipo da propriedade ProcessStartInfo. FileName para a propriedade System. Diagnostics. ProcessStartInfo. Verb (não suportado na fonte compartilhada CLI). Por exemplo, você pode especificar a impressão de um tipo de documento. Além disso, você pode especificar valores de propriedade ProcessStartInfo. Arguments para ser argumentos de linha de comando para passar para o procedimento aberto arquivos. Por exemplo, se você especificar um aplicativo de editor de texto na propriedade ProcessStartInfo. FileName, você pode usar a propriedade ProcessStartInfo. Arguments para especificar um arquivo de texto a ser aberto pelo editor. Entrada padrão é geralmente o teclado, e saída padrão e erro são geralmente a tela do monitor. No entanto, você pode usar o ProcessStartInfo. RedirectStandardInput. ProcessStartInfo. RedirectStandardOutput e ProcessStartInfo. RedirectStandardError propriedades para causar o processo para obter entrada de ou retornar saída para um arquivo ou outro dispositivo. Se você usar o Process. StandardInput. Process. StandardOutput. Ou Process. StandardError no componente Processar, você deve primeiro definir o valor correspondente na propriedade ProcessStartInfo. Caso contrário, o sistema lança uma exceção ao ler ou gravar no fluxo. Defina ProcessStartInfo. UseShellExecute para especificar se deve iniciar o processo usando o shell do sistema operacional. Você pode alterar o valor de qualquer propriedade ProcessStartInfo até o momento em que o processo é iniciado. Depois de iniciar o processo, alterar esses valores não tem efeito. System. Diagnostics. ProcessStartInfo Lista de membros: Construtor padrão. Esse construtor é chamado por construtores de classe derivada para inicializar estado neste tipo. Inicializa uma nova instância da classe ProcessStartInfo sem especificar um nome de arquivo com o qual iniciar o processo. Sobrecarregado:.ctor (string fileName) Inicializa uma nova instância da classe ProcessStartInfo e especifica um nome de arquivo, como um aplicativo ou documento com o qual iniciar o processo. Sobrecarregado:.ctor (string fileName, string arguments) Inicializa uma nova instância da classe ProcessStartInfo e especifica um nome de arquivo de aplicativo com o qual iniciar o processo, bem como um conjunto de argumentos de linha de comando para passar para o aplicativo. Gest ou define o conjunto de argumentos de linha de comando a serem usados ​​ao iniciar o aplicativo. Obtém caminhos de pesquisa para arquivos, diretórios para arquivos temporários, opções específicas do aplicativo e outras informações semelhantes. System. Diagnostics. ProcessStartInfo Detalhes do membro Sobrecarregado ctor 1 Resumo Inicializa uma nova instância da classe ProcessStartInfo sem especificar um nome de arquivo com o qual iniciar o processo. Construtor padrão. Esse construtor é chamado por construtores de classe derivada para inicializar estado neste tipo. C Sintaxe: Comentários Você deve definir pelo menos a propriedade ProcessStartInfo. FileName antes de iniciar o processo. O nome do arquivo é qualquer aplicativo ou documento. Nesse caso, um documento é definido como qualquer tipo de arquivo que tenha uma ação aberta ou padrão associada a ele. Você pode exibir os tipos de arquivos registrados e seus aplicativos associados para o computador usando a caixa de diálogo Opções de pasta disponível no sistema operacional. O botão Avançado leva a uma caixa de diálogo que mostra se há uma ação aberta associada a um tipo de arquivo registrado específico. Opcionalmente, você também pode definir outras propriedades antes de iniciar o processo. A propriedade System. Diagnostics. ProcessStartInfo. Verb (não suportada na fonte compartilhada CLI) fornece ações a serem executadas, como print, com o arquivo indicado na propriedade ProcessStartInfo. FileName. A propriedade ProcessStartInfo. Arguments fornece uma maneira de passar argumentos de linha de comando para o arquivo quando o sistema o abre. Sobrecargado ctor 2 Resumo Inicializa uma nova instância da classe ProcessStartInfo e especifica um nome de arquivo, como um aplicativo ou documento com o qual iniciar o processo. C Sintaxe: Um aplicativo ou documento com o qual iniciar um processo. Comentários O nome do arquivo é qualquer aplicativo ou documento. Nesse caso, um documento é definido como qualquer tipo de arquivo que tenha uma ação aberta ou padrão associada a ele. Você pode exibir os tipos de arquivos registrados e seus aplicativos associados para o computador usando a caixa de diálogo Opções de pasta disponível no sistema operacional. O botão Avançado leva a uma caixa de diálogo que mostra se há uma ação aberta associada a um tipo de arquivo registrado específico. Você pode alterar a propriedade ProcessStartInfo. FileName depois de chamar esse construtor, até o momento em que o processo é iniciado. Depois de iniciar o processo, alterar esses valores não tem efeito. Sobrecargado ctor 3 Resumo Inicializa uma nova instância da classe ProcessStartInfo e especifica um nome de arquivo de aplicativo com o qual iniciar o processo, bem como um conjunto de argumentos de linha de comando para passar para o aplicativo. C Sintaxe: Uma aplicação com a qual iniciar um processo. Argumentos de linha de comando para passar para o aplicativo quando o processo é iniciado. Comentários O nome do arquivo é qualquer aplicativo ou documento. Nesse caso, um documento é definido como qualquer tipo de arquivo que tenha uma ação aberta ou padrão associada a ele. Você pode exibir os tipos de arquivos registrados e seus aplicativos associados para o computador usando a caixa de diálogo Opções de pasta disponível no sistema operacional. O botão Avançado leva a uma caixa de diálogo que mostra se há uma ação aberta associada a um tipo de arquivo registrado específico. Você pode alterar as propriedades ProcessStartInfo. FileName ou ProcessStartInfo. Arguments depois de chamar esse construtor, até o momento em que o processo é iniciado. Depois de iniciar o processo, alterar esses valores não tem efeito. Propriedade: Argumentos (leitura-escrita) Resumo Gest ou define o conjunto de argumentos de linha de comando a serem usados ​​ao iniciar o aplicativo. C Sintaxe: Propriedade: EnvironmentVariables (somente leitura) Resumo Obtém caminhos de pesquisa para arquivos, diretórios para arquivos temporários, opções específicas do aplicativo e outras informações semelhantes. C Sintaxe: Propriedade: RedirectStandardError (read-write) Resumo Obtém ou define um valor indicando se a saída de erro do processo é gravada no processo Membros Process. StandardError, permitindo que você escreva para um destino diferente do fluxo de erro padrão tela do monitor). Usado para gravar dados de erro em um arquivo ou em um log, por exemplo. C Sintaxe: Comentários O componente Process comunica com um processo filho por meio de um pipe. Se um processo filho grava dados suficientes para o pipe para preencher o buffer, a criança irá bloquear até que o pai lê os dados do pipe. Isso pode causar deadlock se o aplicativo estiver lendo toda a saída para erro padrão e saída padrão, por exemplo, usando o código C a seguir. Nesta instância, tanto o pai como os processos filho seriam bloqueados, como o pipe preenchido impede que o processo filho de concluir, enquanto o processo pai está esperando indefinidamente para o processo filho para sair. Esse problema pode ser resolvido movendo o ReadToEnd () antes WaitForExit (). do seguinte modo. Um problema semelhante surge se você redirecionar a saída padrão eo erro padrão e, em seguida, tente ler ambos, por exemplo, usando o seguinte código C. Neste caso, se o processo filho escreve qualquer texto para erro padrão ele irá bloquear o processo, porque o processo pai não pode ler a partir de erro padrão até que ele tenha terminado de leitura de saída padrão. No entanto, o processo pai não lerá de saída padrão até que o processo termina. Uma solução recomendada para esta situação é criar dois threads para que o aplicativo pode ler a saída de cada fluxo em um segmento separado. Propriedade: RedirectStandardInput (read-write) Resumo Obtém ou define um valor indicando se a entrada de comando do processo é lida do processo Membros Process. StandardInput membro, permitindo que você leia de uma fonte diferente do fluxo de entrada padrão (geralmente o teclado). Usado para ler dados de um arquivo, por exemplo. C Sintaxe: Propriedade: RedirectStandardOutput (read-write) Resumo Obtém ou define um valor que indica se a saída do processo é gravada no processo Membros Process. StandardOutput Process, permitindo que você escreva para um destino diferente do fluxo de saída padrão (geralmente o monitor tela). Usado para gravar dados em um arquivo, por exemplo. C Sintaxe: Comentários O componente Process comunica com um processo filho por meio de um pipe. Se um processo filho grava dados suficientes para o pipe para preencher o buffer, a criança irá bloquear até que o pai lê os dados do pipe. Isso pode causar deadlock se o aplicativo estiver lendo toda a saída para erro padrão e saída padrão, por exemplo, usando o código C a seguir. Nesta instância, tanto o pai como os processos filho seriam bloqueados, como o pipe preenchido impede que o processo filho de concluir, enquanto o processo pai está esperando indefinidamente para o processo filho para sair. Esse problema pode ser resolvido movendo o ReadToEnd () antes do WaitForExit (). do seguinte modo. Um problema semelhante surge se você redirecionar a saída padrão eo erro padrão e, em seguida, tente ler ambos, por exemplo, usando o seguinte código C. Neste caso, se o processo filho escreve qualquer texto para erro padrão ele irá bloquear o processo, porque o processo pai não pode ler a partir de erro padrão até que ele tenha terminado de leitura de saída padrão. No entanto, o processo pai não lerá de saída padrão até que o processo termina. Uma solução recomendada para esta situação é criar dois threads para que o aplicativo pode ler a saída de cada fluxo em um segmento separado. Propriedade: UseShellExecute (leitura e gravação) Resumo Obtém ou define um valor indicando se deseja usar o shell do sistema operacional para iniciar o processo. C Sintaxe: Comentários Definir essa propriedade como false permite redirecionar fluxos de entrada, saída e erro. Quando você usa o shell do sistema operacional para iniciar processos, é possível iniciar qualquer documento (que é qualquer tipo de arquivo registrado associado a um executável que tenha uma ação aberta padrão) e executar operações no arquivo, como impressão, com o processo componente. Quando ProcessStartInfo. UseShellExecute é false. Você pode iniciar apenas executáveis ​​com o componente Process. Propriedade: WorkingDirectory (leitura-gravação) Resumo Obtém ou define o diretório inicial para o processo a ser iniciado. C Sintaxe: Comentários Se o diretório já faz parte da variável caminho do sistema, não é necessário repetir o location directorys nesta propriedade.

No comments:

Post a Comment