同时显示每秒在C#中经过的时间的代码执行时间

问题描述 投票:0回答:1

我想知道在Windows窗体中实现此目标的最佳方法是什么-我需要一个窗口,该窗口显示执行代码时经过的时间(1秒2秒等),最长90秒。我现在有一个计时器,实现如下,但是我认为我也需要在那里使用秒表,因为计时器会阻塞主线程。

 static System.Timers.Timer pXRFTimer = new System.Timers.Timer();       
  static int _pXRFTimerCounter = 0;


   private void ScanpXRF()
        {
            _pXRFTimerCounter = 0;
            pXRFTimer.Enabled = true;
            pXRFTimer.Interval = 1000;
            pXRFTimer.Elapsed += new ElapsedEventHandler(pXRFTimer_Tick);
            pXRFTimer.Start();

            //START action to be measured here!
            DoSomethingToBeMeasured();

        }

        private static void pXRFTimer_Tick(Object sender, EventArgs e)
        {
            _pXRFTimerCounter++;

            if (_pXRFTimerCounter >= 90)
            {
                pXRFTimer.Stop();             
            }
            else
            {
                //show time elapsed
            }
        }
c# winforms timer stopwatch
1个回答
0
投票

我不确定您的应用程序的机制,但是可以通过类似这样的方式来计算经过的时间

DateTime startUtc;

private void ScanpXRF()
{
  startUtc = DateTime.NowUtc;
  (...)

  //START action to be measured here!
}

private static void pXRFTimer_Tick(Object sender, EventArgs e)
{
  var elapsed = DateTime.NowUtc - startUtc;
  var elapsedSeconds = elapsed.TotalSeconds; // double so you may want to round.
}
© www.soinside.com 2019 - 2024. All rights reserved.