很多時候,我們會寫下面的這段代碼:
private void button1_Click(object sender, EventArgs e) {Cursor cursor = Cursor.Current;this.Cursor = Cursors.WaitCursor;LongTimeMethod();this.Cursor = cursor; }private void LongTimeMethod() {for (int i = 0; i < 200; i++){label1.Text = i.ToString();label1.Refresh();System.Threading.Thread.Sleep(10);} }
這段代碼在執行LongTimeMethod的時候,設置鼠標的狀態為WaitCursor.
可是這段代碼是有問題的,比如LongTimeMethod() 方法拋出異常的時候,Cursor 就會始終是WaitCursor.
所以比較安全的做法是:
private void button1_Click(object sender, EventArgs e){Cursor cursor = Cursor.Current;try{this.Cursor = Cursors.WaitCursor;LongTimeMethod();}finally {this.Cursor = cursor;}}
?
看到try,finally ,有沒有讓你想到什么呢?,對了using 可以生成try-finally
public class WaitCursor : IDisposable {private Cursor cursor;public WaitCursor(){this.cursor = Cursor.Current;Cursor.Current = Cursors.WaitCursor;}public void Dispose(){Cursor.Current = cursor;} }
使用的時候,只需要:
private void button1_Click(object sender, EventArgs e) {using(new WaitCursor()){LongTimeMethod();} }
?
在using塊結束的時候,會自動的調用WaitCursor的Dispose方法,從而設置當前Cursor 為保存的cursor.
?
如果你仔細的看的話,你會發現Cursor 繼承了IDisposable 接口。
所以有人就說了可以直接:
private void button1_Click(object sender, EventArgs e) {using (Cursor.Current = Cursors.WaitCursor){LongTimeMethod();} }
如果你第一次運行的話,可以發現的確能正常工作,可是事實上上面的代碼是有問題的。
這段代碼會調用Cursors.WaitCursor.Dispose() 方法,從而當你第二次調用的時候,你會得到null,因為WaitCursor已經dispose了:
?
有一種變通的方法,下面的代碼可以正常工作:
private void button1_Click(object sender, EventArgs e) {using (Cursor.Current = new Cursor(Cursors.WaitCursor.CopyHandle())){LongTimeMethod();} }
本文轉自LoveJenny博客園博客,原文鏈接:http://www.cnblogs.com/LoveJenny/archive/2013/03/13/2956922.html,如需轉載請自行聯系原作者