WPF中DispatcherTimer定时器的原理

2 篇文章 0 订阅

1.DispatcherTimer定时器不是单独开启一个线程来运行定时器方法,而是和主线程是同一个线程,只是通过改变运行优先级来实现定时器,当定时器时间到了,主线程就转去执行定时器方法。因此DispatcherTimer定时器不要用来实现执行时间长的任务,不然会使主线程很卡,导致WPF界面很看,是用不友好!

2.DispatcherTimer定时器第一次执行是先等待指定周期的时间再执行定时器方法,而不是先执行再计时;然后,执行完定时器方法后,再等待指定周期的时间。如:如执行周期T = 5s, 定时器方法内的代码所需执行时间为R = 4s;当启动定时器时:先等待5s,然后执行定时器方法(所需时间4s),然后再等待5s,再执行定时器方法(所需时间4s).........

3.测试程序:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Windows.Threading;
using System.Diagnostics;

namespace 定时器原理验证
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        //定时器
        private DispatcherTimer mDataTimer = null;
        //定时器执行次数
        private long timerExeCount = 0;

        public MainWindow()
        {
            InitializeComponent();
            InitTimer();
        }

        private void InitTimer()
        {
            if (mDataTimer == null)
            {
                mDataTimer = new DispatcherTimer();
                mDataTimer.Tick += new EventHandler(DataTimer_Tick);
                mDataTimer.Interval = TimeSpan.FromSeconds(5);
            }
        }

        private void DataTimer_Tick(object sender, EventArgs e)
        {
            s2 = DateTime.Now;
            TimeSpan s = s2 - s1;
            Debug.WriteLine("==========定时器第 " + timerExeCount + " 次执行, 耗时:" + s.TotalMilliseconds + "=========");
            Debug.WriteLine("++++++++++开始休眠第 " + timerExeCount + " 次执行+++++++++");
            s1 = DateTime.Now;
            //System.Threading.Thread.Sleep(2000);
            for (int i = 0; i < 400; ++i)
            {
                System.Threading.Thread.Sleep(10);
            }
            s2 = DateTime.Now;
            TimeSpan t = s2 - s1;
            Debug.WriteLine("----------结束休眠第 " + timerExeCount + " 次执行, 耗时:" + t.TotalMilliseconds + "---------");
            s1 = DateTime.Now;
            ++timerExeCount;
        }
        DateTime s1;
        DateTime s2;
        public void StartTimer()
        {
            if (mDataTimer != null && mDataTimer.IsEnabled == false)
            {
                mDataTimer.Start();
                s1 = DateTime.Now;
            }
        }

        public void StopTimer()
        {
            if (mDataTimer != null && mDataTimer.IsEnabled == true)
            {
                mDataTimer.Stop();
            }
        }

        private void btnStartTimer_Click(object sender, RoutedEventArgs e)
        {
            StartTimer();
        }

        private void btnStopTimer_Click(object sender, RoutedEventArgs e)
        {
            mDataTimer.Stop();
        }
    }
}




  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPFDispatcherTimer是一种用于定时器任务的计时器类,它允许我们在UI线程上执行指定的操作。当使用DispatcherTimer进行倒计时时,如果定时器的Interval属性设置得太小,倒计时会变得非常快。 造成DispatcherTimer倒计时跳的很快的原因是定时器的Interval属性设置过小。Interval属性表示定时器触发Tick事件的时间间隔。如果Interval设置得非常小,比如设置为1毫秒,那么每经过1毫秒,Tick事件就会被触发一次。在较短的时间间隔内,大量的Tick事件会被触发,导致倒计时看起来非常快速。 解决这个问题的方法是适当地调整DispatcherTimer的Interval属性,将其设置为合理的数值。可以根据需要的倒计时速度和精度来设定Interval的值。如果希望倒计时更加平滑,可以将Interval设置为较大的值,比如100毫秒,这样每次Tick事件的触发间隔就较长。 另外一个可能的原因是在Tick事件执行的操作较为耗时,导致倒计时看起来跳的很快。可以通过优化代码或将耗时较长的操作放到后台线程执行来解决这个问题。使用后台线程可以避免在UI线程上执行耗时操作,从而提高倒计时的稳定性和准确性。 总之,要解决DispatcherTimer倒计时跳的很快的问题,需要注意Interval属性的设置和Tick事件的操作耗时,以确保定时器的触发间隔和操作的执行速度能够达到预期的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值