Tuesday 24 October 2017

C # Process Redirectstandardoutput Waitforexit Vb


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. Respondeu Jan 13 15 at 10:35 Exemplo de uso ImplementationExecute um processo e buscar sua saída Já se perguntou como Visual Studio executa um processo - como um compilador - e exibe o texto que retorna em sua própria janela Seu realmente muito fácil - e heres um simples Exemplo de como. Função compartilhada GetProcessText (Processo ByVal como String, ByVal param As String, ByVal workingDir como String) As String Dim p Como Processo Novo Processo este é o nome do processo que queremos executar Processo p. StartInfo. FileName If Not (workingDir) Then P. StartInfo. WorkingDirectory workingDir End Se o parâmetro. StartInfo. Arguments precisar definir isto como false para redirecionar a saída p. StartInfo. UseShellExecute False p. StartInfo. RedirectStandardOutput True iniciar o processo p. Start ler toda a saída aqui nós poderíamos apenas ler a linha Por linha e exibi-lo em uma janela de saída Dim saída como Cadeia p. StandardOutput. ReadToEnd esperar para o processo de encerrar p. WaitForExit Return saída End Function Você também pode gostar. ComentáriosSystem. Diagnostics. ProcessStartInfoClass Assembly: System. dll Namespace: System. Diagnostics Resumo Especifica um conjunto de valores usados ​​ao 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 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: 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