
如图,若是在其他的控件事件中启用timer.enable=true,则如果该事件的进程在结束后,该事件进程销毁,同时timer开启的事件也会销毁,从而无法进入到timer的tick事件中。
调试方法:
若在该事件中无法进入tick事件,在该事件中加入延时函数进行调试,(注意:延时函数不能使用
System.Threading.Thread.Sleep(1000);//延时1000毫秒
该延时函数,该延时函数在执行时,不会相应任何事件)可以创建一个延时方法:
public static void Delay(int milliSecond)//毫秒级延时
{
int start = Environment.TickCount;
while (Math.Abs(Environment.TickCount - start) < milliSecond)//毫秒
{
Application.DoEvents();
}
}
如图所示在timer.enable=true启用后加入delay延时函数,查看是否能进入tick事件。

解决方法:
使用线程的方法来解决,重新开一个线程来执行timer控件的延时,可以使用委托方法进行解决。<

本文探讨了在控件事件中启用Timer时可能遇到的问题,即事件结束可能导致Timer的Tick事件无法触发。通过使用自定义的延迟函数进行调试,发现需要利用线程和委托来确保Timer的正常工作。同步和异步委托在SerialPort_DataReceived事件中的应用被详细阐述,特别指出异步委托能避免线程阻塞和界面卡死问题。建议在处理复杂任务时避免在SerialPort_DataReceived中使用同步委托。

9599

被折叠的 条评论
为什么被折叠?



