C#線程實現暫停與繼續


C#線程暫停與繼續解決方案

原帖地址:http://blog.csdn.net/xiaohui_hubei/article/details/7494553

           昨天, 老師要我們每個人交一個關於黑客方面的程序,想了半天發現端口掃描工具好像好寫點,從昨天寫到今天基本快完成了,給大家看下效果,不要笑話我哦哦(~~)

端口掃描器

圖1  端口掃描器

        這個程序里面有一些地方不太滿意,就是掃描的暫停與繼續實現時,使用的是Thread.Suspend和Thread.Resume而這兩個方法,在 VS2010里提示已經過時,不建議使用,在網上查閱了一些資料,發現有個事件通知的方法很好,事件通知的大致原理是,線程在執行過程中暫停,等到其他線 程通知時才繼續執行下去,這樣的確是可以起到暫停與繼續的效果。但是,這種暫停是被動的,我需要的是主動暫停,即點下按鈕,線程暫停,再點下按鈕,線程繼 續執行。

         最終,我想了一種比較另類的方法,大致思路如下:還是采用事件通知的方式,在線程中等待通知,直到來通知了才繼續執行,而主線程(窗體線程)中使用一個計 時器System.Windows.Forms.Timer 來不停的通知線程,如果計時器間隔時間設置的足夠小,基本上看不出停頓。此時,程序的暫停與繼續實現就很簡單了,相信大家已經想到了,只要在通過控制計時 器的Stop()和Start()就可控制線程的暫停與繼續了。

下面是一個下的demo:

運行截圖:

圖2  demo運行效果

C#源代碼:

[csharp] view plain copy print ?
    1. using System;  
    2. using System.Windows.Forms;  
    3. using System.Threading;  
    4.   
    5. namespace 線程暫停與繼續實現  
    6. {  
    7.     public partial class Form1 : Form  
    8.     {  
    9.         //計時器  
    10.         private System.Windows.Forms.Timer tm = new System.Windows.Forms.Timer();  
    11.         //自動重置事件類    
    12.         //主要用到其兩個方法 WaitOne() 和 Set() , 前者阻塞當前線程,后者通知阻塞線程繼續往下執行  
    13.         AutoResetEvent autoEvent = new AutoResetEvent(false);  
    14.   
    15.         public Form1()  
    16.         {  
    17.             InitializeComponent();  
    18.             ProgressBar.CheckForIllegalCrossThreadCalls = false;  
    19.             tm.Interval = 1;  
    20.             tm.Tick += new EventHandler(tm_Tick);  
    21.         }  
    22.   
    23.         //計時器 事件  
    24.         void tm_Tick(object sender, EventArgs e)  
    25.         {  
    26.             autoEvent.Set(); //通知阻塞的線程繼續執行  
    27.         }  
    28.   
    29.         //啟動  
    30.         private void btnStart_Click(object sender, EventArgs e)  
    31.         {  
    32.             tm.Start();  
    33.   
    34.             Thread t = new Thread(DoWork);  
    35.             t.Start();  
    36.         }  
    37.           
    38.         //在線程中執行的方法  
    39.         private void DoWork()  
    40.         {  
    41.             while (progressBar1.Value < progressBar1.Maximum)  
    42.             {  
    43.                 progressBar1.PerformStep();  
    44.                 autoEvent.WaitOne();  //阻塞當前線程,等待通知以繼續執行  
    45.             }  
    46.         }  
    47.   
    48.         //暫停  
    49.         private void btnSuspend_Click(object sender, EventArgs e)  
    50.         {  
    51.             tm.Stop();  
    52.         }  
    53.   
    54.         //繼續  
    55.         private void btnResume_Click(object sender, EventArgs e)  
    56.         {  
    57.             tm.Start();  
    58.         }  
    59.     }  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM