您的位置:首页 >c#如何使用Timer控件_c#Timer控件最全用法总结
发布于2026-05-02 阅读(0)
扫一扫,手机访问

别急着 new Timer() 就动手——选错类型,UI会卡死、部署会失败、定时器甚至会“静默消失”。
System.Windows.Forms.Timer为什么是它?因为它的 Tick 事件直接在 UI 线程上触发。这意味着你可以安全地写 lblStatus.Text = “running”,而不用担心抛出那个经典的 InvalidOperationException: Cross-thread operation not valid。
但凡事都有代价。它的“UI线程依赖”特性是把双刃剑:如果在 Tick 事件里执行耗时操作(比如读取大文件或调用同步HTTP请求),整个窗体就会陷入假死——鼠标拖不动、按钮点不了、窗口也无法重绘。
ArgumentException。Start()/Stop(),或者设置 Enabled = true/false。千万别试图通过修改 Interval 来停止它,这不是它的设计意图。Tick 事件里调用 Thread.Sleep() 或进行长时间的同步 I/O。如果确实需要等待,可以考虑使用 await Task.Delay() 并配合 async void Tick 事件处理程序(需要 .NET 4.5+,并注意防范重入问题)。timer1,很容易与其他定时器混淆,建议第一时间重命名为有意义的名称。System.Threading.Timer这是后台任务的“轻骑兵”。它不依赖任何 UI 框架,纯粹基于线程池回调,因此非常轻量、无状态,且不会占用 UI 线程。
但“轻量”也意味着“不近人情”:它根本不知道窗体在哪里,因此绝对不能在其中直接操作 TextBox.Text 这类 UI 控件——一碰就崩。
period 参数如果设为 Timeout.Infinite 或 0,它就只执行一次。想要周期运行,必须确保 period > 0,例如 TimeSpan.FromSeconds(5)。try/catch 包裹,至少也要记录日志。Main() 方法里,没有保存到类的字段中),垃圾回收器(GC)可能会将其回收,导致出现“明明启动了却没反应”的灵异现象。Dispose(),或者使用 using 语句块。在长期运行的服务中,建议将其作为类的字段存储,并进行手动生命周期管理。System.Timers.Timer 加 SynchronizingObject它本质上是 System.Threading.Timer 的封装,但提供了更符合 C# 事件编程习惯的 Elapsed 事件。其关键在于 SynchronizingObject 属性:你可以指定一个实现了 ISynchronizeInvoke 接口的对象(比如 WinForms 的 Form 或 Control),这样 Elapsed 事件的回调就会自动封送到 UI 线程执行。
SynchronizingObject,Elapsed 事件将在线程池线程中运行,行为与 System.Threading.Timer 一致。SynchronizingObject,它内部会调用 BeginInvoke,你就可以在事件处理程序中安全地写 label.Text = “...”; 了。AutoReset = false 时,只触发一次;设为 true(默认值)才会循环触发。这比 System.Threading.Timer 的构造参数更直观。Elapsed 事件处理程序中直接调用 timer.Stop(),这可能会引发“正在触发事件时关闭定时器”的竞态条件。更安全的做法是先将 AutoReset 设为 false,然后在事件处理末尾再调用 Stop()。PeriodicTimer + IHostedService如果你正在开发 ASP.NET Core 后台服务或基于通用主机的控制台应用,System.Threading.Timer 虽然能用,但其生命周期很难与宿主服务对齐——服务停止了,Timer 可能还在后台运行。而 PeriodicTimer 是可等待的(awaitable),与 IHostedService 的 StartAsync/StopAsync 生命周期配合起来更加自然。
WaitForNextTickAsync()。典型用法是写在 while (await timer.WaitForNextTickAsync()) { … } 这样的循环里。Dispose(),否则会造成资源泄漏。在 StopAsync 方法中调用 timer.Dispose() 是标准做法。最后也是最关键的一点提醒:Timer 并不是“只要 new 出来就一定会运行”。它的行为高度依赖于上下文——UI 线程、线程池、宿主生命周期、异常处理粒度。写完代码后,别只测试“第一次能否触发”,一定要验证“连续运行 5 分钟是否会漏掉 tick”、“抛出异常后能否正常恢复”以及“服务关闭时是否能干净退出”。这些才是定时器稳定运行的真正考验。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9