C # useshellexecute waitforexit
App Store를 통해 가져 오기 우리의 응용 프로그램 에서이 게시물을 읽으십시오!
Process. start : 출력을 얻는 방법?
내 Mono / app에서 외부 명령 줄 프로그램을 실행하고 싶습니다. 예를 들어, mencoder를 실행하고 싶습니다. 가능한가?
커맨드 라인 쉘 출력을 내 텍스트 상자에 써주시겠습니까? 시간 경과와 함께 진행률 표시 줄을 나타내는 수치 값을 얻으려면?
Process 개체를 만들 때 StartInfo를 적절하게 설정합니다.
다음 프로세스를 시작하고 그것에서 읽을 :
int. Parse () 또는 int. TryParse ()를 사용하여 문자열을 숫자 값으로 변환 할 수 있습니다. 읽은 문자열에 유효하지 않은 숫자가있는 경우 먼저 문자열 조작을해야 할 수도 있습니다.
출력을 동 기적 또는 비동기 적으로 처리 할 수 있습니다.
출력과 오류를 모두 처리하는 것이 더 좋습니다. 개별적으로 처리해야합니다.
(*) 일부 명령 (여기서는 StartInfo. Arguments)에 / c 지시문을 추가해야합니다. 그렇지 않으면 WaitForExit ()에 프로세스가 고정됩니다.
출력과 관련하여 복잡한 연산을 수행 할 필요가없는 경우 핸들러를 직접 인라인에 추가하기 만하면 OutputHandler 메소드를 무시할 수 있습니다.
이 작업을 수행하는 표준 방법은 Process 'StandardOutput 스트림에서 읽는 것입니다. 연결된 MSDN 문서에는 예제가 있습니다. 마찬가지로 StandardError에서 읽고 StandardInput에 쓸 수 있습니다.
좋아, 오류 및 출력 모두 읽기를 원하지만 다른 솔루션 (나와 같은)에서 제공되는 솔루션 중 하나에서 교착 상태가 발생하는 사람은 StandardOutput 속성에 대한 MSDN 설명을 읽은 후 솔루션을 작성했습니다.
답은 T30의 코드를 기반으로합니다 :
당신은 2 개의 프로세스가 공유하는 메모리를 사용하여 통신 할 수 있습니다. MemoryMappedFile을 체크 아웃하십시오.
당신은 주로 "using"문을 사용하여 부모 프로세스에 mmf 파일을 매핑 한 다음 종료 될 때까지 두 번째 프로세스를 만들고 BinaryWriter를 사용하여 mmf에 결과를 쓴 다음 부모 프로세스를 사용하여 mmf에서 결과를 읽습니다. , 명령 줄 인수를 사용하여 mmf 이름을 전달하거나 하드 코드 할 수도 있습니다.
부모 프로세스에서 매핑 된 파일을 사용할 때 매핑 된 파일이 부모 프로세스에서 해제되기 전에 자식 프로세스에서 매핑 된 파일에 결과를 기록해야합니다.
예 : 상위 프로세스.
이 샘플을 사용하려면 내부에 2 개의 프로젝트가있는 솔루션을 생성 한 다음 % childDir % / bin / debug에서 하위 프로세스의 빌드 결과를 가져 와서 % parentDirectory % / bin / debug에 복사 한 다음 부모 프로젝트
childDir 및 parentDirectory는 PC의 행운을 빌어 프로젝트의 폴더 이름입니다. :)
이것은 mencoder에 의존합니다. 명령 줄에서이 상태를 출력하면 예 :)
C # useshellexecute waitforexit
App Store를 통해 가져 오기 우리의 응용 프로그램 에서이 게시물을 읽으십시오!
Process. WaitForExit를 사용하는 방법.
나는 '때때로'VB에서 작동하는 3 부 애플리케이션을 호출하고있다. (자체 호스팅 WCF이다.) 하지만 때로는 타사 앱이 영원히 멈춰 버리기 때문에 90 초 타이머를 추가했습니다. 문제는, 시간이 초과되었는지 어떻게 알 수 있습니까?
코드는 다음과 같습니다.
제가하고 싶은 것은 이것과 같습니다.
메서드 반환 값 확인 - msdn. microsoft / en - us / library /ty0d8k56.aspx - 호출 시간이 초과되면 False를 반환합니다.
과거에는 WaitForExit을 사용할 때 앱이 멈추는 문제가있었습니다.
C # UseShellExecute = TRUE입니다.
processInfo = 새로운 ProcessStartInfo ( "cmd. exe");
processInfo. UseShellExecut e = true;
processInfo. WorkingDirecto ry = "C : \ Windows \ System32";
processInfo. RedirectStanda rdError = false;
processInfo. RedirectStanda rdOutput = false;
processInfo. RedirectStanda rdInput = false;
processInfo. Arguments = & quot; schtasks / run / s server_name batname. bat & quot;;
Facebook Twitter LinkedIn 전문가 교환 / 질문 / 28944964 / C-UseShellExecute-TRUE. html 사본.
질문하고 해결책을 찾으려면.
cyimxtck (7 개의 댓글) it_saige (4 개의 댓글)
그런 다음 권한을 높이기 위해 UAC를 사용합니다. 애플리케이션 매니페스트를 임베드해야 할 수도 있습니다.
다음 출력을 생성합니다. - & quot; runas & quot; 나는 얻는다 : - saige-
쉘 (schtasks / run / s server_name batname. bat)
독립 소프트웨어 벤더 : 우리는 당신의 의견을 원합니다.
우리는 귀하의 의견을 소중하게 생각합니다.
Yeti Cooler, Amazon eGift 카드 및 영화 eGift 카드!
그러나 작업 스케줄러 API를 사용하면 더 유용 할 수 있습니다. 바트 드 스 메트 (Bart De Smet)
추천 게시물.
구성 가이드 및 모범 사례.
이 가이드를 읽고 Data ONTAP을 조정하고 애플리케이션 일관성있는 백업을 생성하며 NetApp 스토리지 스냅 샷에서 신속하게 복구 할 수있는 방법을 학습하십시오. 버전 9.5에는 또한 가장 큰 엔터프라이즈 환경의 요구 사항을 충족시키는 성능 및 확장 성 향상 기능이 포함되어 있습니다.
유사한 문제가 발생하는 경우 관련 질문을하십시오.
문서 관리 문서 이미징 프린터 및 스캐너 소프트웨어 - 기타 이미지 및 사진 사진 / 그래픽 소프트웨어, OCR, * tiff, * PaperPort, * PDF.
추천 코스.
지난 7 일 동안 757 명의 회원이 질문을하고 개인화 된 솔루션을 받았습니다.
500,000 명의 기술 전문가 커뮤니티에 가입하여 질문하십시오.
당신의 대답을 즐겼습니까?
더 많은 솔루션이나 질문을 원하시면 커뮤니티에 가입하십시오.
사용 예제.
나는이 방법으로 그것을 해결했다.
나는 입력, 출력 및 오류 모두를 리디렉션하고 출력 및 오류 스트림에서 읽기를 처리했습니다. 이 솔루션은 Windows 7과 Windows 8 모두 SDK 7 - 8.1에서 작동합니다.
Mark Beers, Rob, stevejay 대답을 고려하여 비동기 스트림 읽기를 사용하여 문제를 해결할 클래스를 만들려고했습니다. 그렇게하면 비동기 프로세스 출력 스트림 읽기와 관련된 버그가 있음을 알았습니다.
당신은 그렇게 할 수 없습니다 :
System. InvalidOperationException이 발생합니다 : StandardOut가 리디렉션되지 않았거나 프로세스가 아직 시작되지 않았습니다.
그런 다음 프로세스가 시작된 후 비동기 출력 읽기를 시작해야합니다.
이렇게하면 출력 스트림이 비동기로 설정되기 전에 데이터를받을 수 있기 때문에 경쟁 조건을 만듭니다.
그렇다면 어떤 사람들은 스트림을 비동기로 설정하기 전에 스트림을 읽어야한다고 말할 수 있습니다. 그러나 같은 문제가 발생합니다. 동기 읽기 사이에 경쟁 조건이 있으며 스트림을 비동기 모드로 설정합니다.
"Process"와 "ProcessStartInfo"가 설계된 실제 방식으로 프로세스의 출력 스트림을 안전하게 비동기 적으로 읽는 방법은 없습니다.
다른 사용자가 제안한 것과 같이 비동기 읽기를 사용하는 것이 좋습니다. 그러나 경쟁 조건으로 인해 정보가 누락 될 수 있음을 알고 있어야합니다.
위의 답변 중 하나도 해당 작업을 수행하지 않습니다.
롭 솔루션이 중단되고 'Mark Byers'솔루션이 폐기 된 예외를 얻습니다. (다른 답변의 '솔루션'을 시도했습니다.)
그래서 나는 또 다른 해결책을 제안하기로 결정했다.
이 코드는 디버깅되어 완벽하게 작동합니다.
이것이 간단하고 더 나은 접근 방법입니다 (우리는 AutoResetEvent가 필요 없습니다) :
나는 같은 문제가 있었지만 그 이유는 다르다. 그러나 Windows 8에서는 발생하지만 Windows 7에서는 발생하지 않습니다. 다음 줄이 문제를 일으킨 것으로 보입니다.
해결책은 UseShellExecute를 비활성화하지 않는 것입니다. 원하지 않는 쉘 팝업 창을 받았지만 특별한 일이 일어나지 않을 때까지 기다리는 프로그램보다 훨씬 낫습니다. 그래서 다음과 같은 해결 방법을 추가했습니다.
이제 나를 귀찮게하는 것은 Windows 8에서 왜 이런 일이 일어나고 있는지입니다.
소개.
현재 허용되는 응답이 작동하지 않고 (예외가 throw 됨) 해결 방법이 너무 많지만 완전한 코드가 없습니다. 이것이 대중적인 질문이기 때문에 많은 사람들의 시간을 낭비하는 것은 분명합니다.
Mark Byers의 대답과 Karol Tyl의 대답을 결합하여 Process. Start 메서드를 사용하는 방법을 기반으로 전체 코드를 작성했습니다.
git 명령을 통해 진행 대화 상자를 만드는 데 사용했습니다. 이것이 내가 그것을 사용한 방법입니다 :
이론적으로 stdout과 stderr를 결합 할 수도 있지만 테스트하지는 않았습니다.
나는 이것이 늙다는 것을 알고 있지만이 전체 페이지를 읽은 후에는 해결할 수있는 코드가 없기 때문에 무하마드 레 한 (Muhammad Rehan)을 시도하지는 않았다. . 그것이 완전히 진실하지 않은 경우 작동하지 않는다고 말할 때, 때로는 잘 작동 할 것입니다. EOF 마크 전에 출력의 길이와 관련이 있다고 생각합니다.
어쨌든, 나를 위해 일한 솔루션은 다른 스레드를 사용하여 StandardOutput 및 StandardError를 읽고 메시지를 작성하는 것이 었습니다.
희망이 사람이 도움이되기를 바랍니다, 누가 힘들 수 있다고 생각!
내부 타임 아웃과 생성 된 애플리케이션에 의한 StandardOutput 및 StandardError의 사용으로 인해 다른 솔루션 (EM0를 포함하여)은 여전히 내 애플리케이션에 대해 교착 상태입니다. 여기 나를 위해 일한 것입니다 :
편집 : StartInfo의 초기화를 코드 샘플에 추가했습니다.
이 게시물 어쩌면 구식하지만 난 왜 그것이 일반적으로 끊어지는 주된 원인은 redirectStandardoutput에 대한 스택 오버 플로우 때문이거나 redirectStandarderror가있는 경우입니다.
출력 데이터 또는 오류 데이터가 크기 때문에 무한정 지속되는 동안 정지 시간이 발생합니다.
App Store를 통해 가져 오기 우리의 응용 프로그램 에서이 게시물을 읽으십시오!
Process. WaitForExit를 사용하는 방법.
나는 '때때로'VB에서 작동하는 3 부 애플리케이션을 호출하고있다. (자체 호스팅 WCF이다.) 하지만 때로는 타사 앱이 영원히 멈춰 버리기 때문에 90 초 타이머를 추가했습니다. 문제는, 시간이 초과되었는지 어떻게 알 수 있습니까?
코드는 다음과 같습니다.
제가하고 싶은 것은 이것과 같습니다.
메서드 반환 값 확인 - msdn. microsoft / en - us / library /ty0d8k56.aspx - 호출 시간이 초과되면 False를 반환합니다.
과거에는 WaitForExit을 사용할 때 앱이 멈추는 문제가있었습니다.
C # UseShellExecute = TRUE입니다.
processInfo = 새로운 ProcessStartInfo ( "cmd. exe");
processInfo. UseShellExecut e = true;
processInfo. WorkingDirecto ry = "C : \ Windows \ System32";
processInfo. RedirectStanda rdError = false;
processInfo. RedirectStanda rdOutput = false;
processInfo. RedirectStanda rdInput = false;
processInfo. Arguments = & quot; schtasks / run / s server_name batname. bat & quot;;
Facebook Twitter LinkedIn 전문가 교환 / 질문 / 28944964 / C-UseShellExecute-TRUE. html 사본.
질문하고 해결책을 찾으려면.
cyimxtck (7 개의 댓글) it_saige (4 개의 댓글)
그런 다음 권한을 높이기 위해 UAC를 사용합니다. 애플리케이션 매니페스트를 임베드해야 할 수도 있습니다.
다음 출력을 생성합니다. - & quot; runas & quot; 나는 얻는다 : - saige-
쉘 (schtasks / run / s server_name batname. bat)
독립 소프트웨어 벤더 : 우리는 당신의 의견을 원합니다.
우리는 귀하의 의견을 소중하게 생각합니다.
Yeti Cooler, Amazon eGift 카드 및 영화 eGift 카드!
그러나 작업 스케줄러 API를 사용하면 더 유용 할 수 있습니다. 바트 드 스 메트 (Bart De Smet)
추천 게시물.
구성 가이드 및 모범 사례.
이 가이드를 읽고 Data ONTAP을 조정하고 애플리케이션 일관성있는 백업을 생성하며 NetApp 스토리지 스냅 샷에서 신속하게 복구 할 수있는 방법을 학습하십시오. 버전 9.5에는 또한 가장 큰 엔터프라이즈 환경의 요구 사항을 충족시키는 성능 및 확장 성 향상 기능이 포함되어 있습니다.
유사한 문제가 발생하는 경우 관련 질문을하십시오.
문서 관리 문서 이미징 프린터 및 스캐너 소프트웨어 - 기타 이미지 및 사진 사진 / 그래픽 소프트웨어, OCR, * tiff, * PaperPort, * PDF.
추천 코스.
지난 7 일 동안 757 명의 회원이 질문을하고 개인화 된 솔루션을 받았습니다.
500,000 명의 기술 전문가 커뮤니티에 가입하여 질문하십시오.
당신의 대답을 즐겼습니까?
더 많은 솔루션이나 질문을 원하시면 커뮤니티에 가입하십시오.
사용 예제.
나는이 방법으로 그것을 해결했다.
나는 입력, 출력 및 오류 모두를 리디렉션하고 출력 및 오류 스트림에서 읽기를 처리했습니다. 이 솔루션은 Windows 7과 Windows 8 모두 SDK 7 - 8.1에서 작동합니다.
Mark Beers, Rob, stevejay 대답을 고려하여 비동기 스트림 읽기를 사용하여 문제를 해결할 클래스를 만들려고했습니다. 그렇게하면 비동기 프로세스 출력 스트림 읽기와 관련된 버그가 있음을 알았습니다.
당신은 그렇게 할 수 없습니다 :
System. InvalidOperationException이 발생합니다 : StandardOut가 리디렉션되지 않았거나 프로세스가 아직 시작되지 않았습니다.
그런 다음 프로세스가 시작된 후 비동기 출력 읽기를 시작해야합니다.
이렇게하면 출력 스트림이 비동기로 설정되기 전에 데이터를받을 수 있기 때문에 경쟁 조건을 만듭니다.
그렇다면 어떤 사람들은 스트림을 비동기로 설정하기 전에 스트림을 읽어야한다고 말할 수 있습니다. 그러나 같은 문제가 발생합니다. 동기 읽기 사이에 경쟁 조건이 있으며 스트림을 비동기 모드로 설정합니다.
"Process"와 "ProcessStartInfo"가 설계된 실제 방식으로 프로세스의 출력 스트림을 안전하게 비동기 적으로 읽는 방법은 없습니다.
다른 사용자가 제안한 것과 같이 비동기 읽기를 사용하는 것이 좋습니다. 그러나 경쟁 조건으로 인해 정보가 누락 될 수 있음을 알고 있어야합니다.
위의 답변 중 하나도 해당 작업을 수행하지 않습니다.
롭 솔루션이 중단되고 'Mark Byers'솔루션이 폐기 된 예외를 얻습니다. (다른 답변의 '솔루션'을 시도했습니다.)
그래서 나는 또 다른 해결책을 제안하기로 결정했다.
이 코드는 디버깅되어 완벽하게 작동합니다.
이것이 간단하고 더 나은 접근 방법입니다 (우리는 AutoResetEvent가 필요 없습니다) :
나는 같은 문제가 있었지만 그 이유는 다르다. 그러나 Windows 8에서는 발생하지만 Windows 7에서는 발생하지 않습니다. 다음 줄이 문제를 일으킨 것으로 보입니다.
해결책은 UseShellExecute를 비활성화하지 않는 것입니다. 원하지 않는 쉘 팝업 창을 받았지만 특별한 일이 일어나지 않을 때까지 기다리는 프로그램보다 훨씬 낫습니다. 그래서 다음과 같은 해결 방법을 추가했습니다.
이제 나를 귀찮게하는 것은 Windows 8에서 왜 이런 일이 일어나고 있는지입니다.
소개.
현재 허용되는 응답이 작동하지 않고 (예외가 throw 됨) 해결 방법이 너무 많지만 완전한 코드가 없습니다. 이것이 대중적인 질문이기 때문에 많은 사람들의 시간을 낭비하는 것은 분명합니다.
Mark Byers의 대답과 Karol Tyl의 대답을 결합하여 Process. Start 메서드를 사용하는 방법을 기반으로 전체 코드를 작성했습니다.
git 명령을 통해 진행 대화 상자를 만드는 데 사용했습니다. 이것이 내가 그것을 사용한 방법입니다 :
이론적으로 stdout과 stderr를 결합 할 수도 있지만 테스트하지는 않았습니다.
나는 이것이 늙다는 것을 알고 있지만이 전체 페이지를 읽은 후에는 해결할 수있는 코드가 없기 때문에 무하마드 레 한 (Muhammad Rehan)을 시도하지는 않았다. . 그것이 완전히 진실하지 않은 경우 작동하지 않는다고 말할 때, 때로는 잘 작동 할 것입니다. EOF 마크 전에 출력의 길이와 관련이 있다고 생각합니다.
어쨌든, 나를 위해 일한 솔루션은 다른 스레드를 사용하여 StandardOutput 및 StandardError를 읽고 메시지를 작성하는 것이 었습니다.
희망이 사람이 도움이되기를 바랍니다, 누가 힘들 수 있다고 생각!
내부 타임 아웃과 생성 된 애플리케이션에 의한 StandardOutput 및 StandardError의 사용으로 인해 다른 솔루션 (EM0를 포함하여)은 여전히 내 애플리케이션에 대해 교착 상태입니다. 여기 나를 위해 일한 것입니다 :
편집 : StartInfo의 초기화를 코드 샘플에 추가했습니다.
이 게시물 어쩌면 구식하지만 난 왜 그것이 일반적으로 끊어지는 주된 원인은 redirectStandardoutput에 대한 스택 오버 플로우 때문이거나 redirectStandarderror가있는 경우입니다.
출력 데이터 또는 오류 데이터가 크기 때문에 무한정 지속되는 동안 정지 시간이 발생합니다.
No comments:
Post a Comment