Application.DoEvent浅析及实时刷新控件状态

Application.DoEvent浅析及实时刷新控件状态  

我们再写一个实时更改控件状态的循环时会经常发现控件没有实时的刷新,而是直接显示了最后的控件状态,例如:

我在一个button的Click事件中写入下面这行代码,想要实时的去更改textbox的值,但是真正的效果是一次就到了9999

 for (int i = 0; i < 10000; i++) 

 {
     textBox1.Text = i.ToString();
  }

百思不得只好骑姐啊,到网上查了些资料,勉强弄懂了些:

当运行 Windows 窗体时,它将创建新窗体,然后该窗体等待处理事件。该窗体在每次处理事件时,均将处理与该事件关联的所有代码。所有其他事件在队列中等待。当代码处理事件时,应用程序不会响应。例如,如果将甲窗口拖到乙窗口之上,则乙窗口不会重新绘制。

也就是说我会先把我这个button里的事件先处理完,才去处理控件重绘的事件。如果不信你可以逐语句的运行下看看,在button事件没有运行完之前,textBox里的值是空的,当你button的Click事件运行完毕之后textbox才会有值显示。

解决的办法有很多:

Application.DoEvents();

DoEvents in your code, your application can handle the other events.' xmlspace="preserve" >如果在代码中调用 DoEvents,则您的应用程序可以处理其他事件。ListBox and add DoEvents to your code, your form repaints when another window is dragged over it.' xmlspace="preserve" >例如,如果您有向ListBox 添加数据的窗体,并将 DoEvents 添加到代码中,那么当将另一窗口拖到您的窗体上时,该窗体将重新绘制。DoEvents from your code, your form will not repaint until the click event handler of the button is finished executing.' xmlspace="preserve" >如果从代码中移除 DoEvents,那么在按钮的单击事件处理程序执行结束以前,您的窗体不会重新绘制。

DoEvents from your code, your form will not repaint until the click event handler of the button is finished executing.' xmlspace="preserve" >调用此方法将导致当前线程暂停,但处理所有等待窗口消息。如果消息导致事件触发,则应用程序代码的其他区域可以执行。这可能会导致您的应用程序展示难以调试的意外的行为。如果您执行需要很长时间的操作或计算,则通常更为可取的是在新线程上执行这些操作。

因为每次调用他都会导致当前线程暂停,若果是大数据量的循环的话,这个方法是比较耗时的,所以我更喜欢用下面的方法:

Control.Update();Control.Refresh();

Control.Update 方法:使控件重绘其工作区内的无效区域。
Control.Refresh 方法:强制控件使其工作区无效并立即重绘自己和任何子控件;

至于这两个方法有什么区别,我推荐大家看另一个人的博客:

http://blog.youkuaiyun.com/minghe2009/article/details/6577066

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值