2016-07-13 6 views
-1

プロセスの停止に問題があります。C#プロセスがキリングプログラムをキャンセルしていません

私は1つのコードを試みましたが、その殺害のプログラムはプロセスを停止しませんでした。

プログラムForm Design

例:

私に、ping 127.0.0.1とその開始無限のping(-t)を試してみて、私は、プロセスを停止する必要がありますが、そのちょうどそれを殺します。

「停止!」をクリックするとプログラムは停止して閉じます。

マイコード:

まず、:私はコピーして貼り付けコードをVSにし、それが次の変更を使用して動作するようになった

namespace PingProgramm 
{ 
    public partial class Form1 : Form 
    { 
     public Form1() 
     { 
      InitializeComponent(); 
     } 
     Thread th; 
     private void button1_Click(object sender, EventArgs e) 
     { 
      th = new Thread(thread1); 
      th.Start(); 
     } 

     public void thread1() 
     { 
      try 
      { 
       string command = "/c ping -t " + textBox1.Text; 
       ProcessStartInfo procStartInfo = new ProcessStartInfo("CMD", command); 
       Process proc = new Process(); 
       proc.StartInfo = procStartInfo; 
       procStartInfo.RedirectStandardOutput = true; 
       procStartInfo.RedirectStandardInput = true; 
       procStartInfo.RedirectStandardError = true; 
       procStartInfo.UseShellExecute = false; 
       procStartInfo.CreateNoWindow = true; 
       proc.OutputDataReceived += new DataReceivedEventHandler(proc_OutputDataReceived); 
       proc.Start(); 
       proc.BeginOutputReadLine(); 
       proc.WaitForExit(); 
      } 
      catch (Exception) 
      { 
       //if an error occurs with in the try block, it will handled here. 
      } 
     } 
     void proc_OutputDataReceived(object sender, DataReceivedEventArgs e) 
     { 
      if (stop) 
      { 
       // sender is our process instance 
       // so we can cast that safely here 
       var proc = (Process)sender; 
       // brutally kill it 
       proc.Pause(); 
       // or more gently, send a ctrl+C 
       // http://stackoverflow.com/a/285041/578411 
       proc.StandardInput.Pause(); 
      } 
      if (e.Data != null) 
      { 
       string newLine = e.Data.Trim() + Environment.NewLine; 
       MethodInvoker append =() => richTextBox1.Text += newLine; 
       richTextBox1.BeginInvoke(append); 
      } 
     } 
     bool firstTime = true; 
     private void textBox1_Click(object sender, EventArgs e) 
     { 
      if (firstTime) 
      { 
       firstTime = false; 
       textBox1.Clear(); 
      } 
     } 

     bool stop = false; 
     private void button2_Click(object sender, EventArgs e) 
     { 
      stop = true; 
     } 
    } 
} 

幸運を祈り、

KLDesigns

+0

あなたが書いたプロセス拡張メソッドは 'Pause()'ですか、もしそうなら、私たちはそれを見ることができますか?私は['Process'](https://msdn.microsoft.com/en-us/library/system.diagnostics.process(v = vs.110).aspx)クラスでそれを見ることはできません。また、何らかの理由で悪い考えのように思える、OutputReceivedイベントハンドラの内部でProcessを使用しているため、プログラムがクラッシュしているかどうかは疑問です。私はまた 'Pause()'がここにあるものとして失われています: 'proc.StandardInput.Pause();'。 – Quantic

+0

だから、あなたは 'proc.Pause()'という行の上に "残酷に殺す"というコメントを持っています。コメントが意味することを正確に実行しているように見えます。また、リンクされたSOの投稿から、 'Pause()'ではなく 'proc.StandardInput.Close()'を使用するように言います。あなたはおそらく少なくとも1つの例外がスローされている...デバッグする方法についていくつかの研究をしてください。 –

+0

「+ =」で登録されたイベントがあります。プロセスを停止しても、ping応答の発生は直ちに停止しません。応答が停止するまでには5〜10秒かかります。例外を取得しないように、プロセスを停止する前にOutputDataReceivedイベントの登録を解除することをお勧めします。 – jdweng

答えて

1

"proc.WaitForExit();をコメントアウトまたは削除するthread1の定義では...これはスレッドが終了するのを待っている場所ではなく、問題を引き起こしているようです。

次に、変更は次のようにproc_OutputDataReceived:

void proc_OutputDataReceived(object sender, DataReceivedEventArgs e) 
{ 
    if (stop) 
    { 
     var proc = (Process)sender; 

     stop = false; // allows you to spawn a new thread after stopping the first 
     proc.SynchronizingObject = this; // puts the form in charge of async communication 
     proc.Kill(); // terminates the thread 
     proc.WaitForExit(); // thread is killed asynchronously, so this goes here... 

    } 
    if (e.Data != null) 
    { 
     string newLine = e.Data.Trim() + Environment.NewLine; 
     MethodInvoker append =() => richTextBox1.Text += newLine; 
     richTextBox1.BeginInvoke(append); 
    } 
} 

をそれらの変更を使用すると、ping要求を停止してから新しいものを再起動することができます。

関連する問題