Как закодировать таймер, который запускается с 0: 0: 0: 0?

Следующий таймер всегда запускается с текущей даты. Как я могу изменить код, чтобы он начинался с 0: 0: 0: 0? Итак, вместо отображения:

Событие Elapsed было создано в 09: 40: 31.084. Событие Elapsed было поднято в 09: 40: 33.100. Событие Elapsed было поднято в 09: 40: 35.100. ...

он отобразит:

Событие Elapsed было вызвано в 00: 00: 01.084. Событие Elapsed было вызвано в 00: 00: 02.084. Событие Elapsed было вызвано в 00: 00: 03.084. ...

Спасибо за помощь.

using System;
using System.Timers;

public class Example
{
   private static System.Timers.Timer aTimer;

   public static void Main()
   {
      SetTimer();

      Console.WriteLine("\nPress the Enter key to exit the application...\n");
      Console.WriteLine("The application started at {0:HH:mm:ss.fff}", DateTime.Now);
      Console.ReadLine();
      aTimer.Stop();
      aTimer.Dispose();

      Console.WriteLine("Terminating the application...");
   }

   private static void SetTimer()
   {
        // Create a timer with a two second interval.
        aTimer = new System.Timers.Timer(2000);
        // Hook up the Elapsed event for the timer. 
        aTimer.Elapsed += OnTimedEvent;
        aTimer.AutoReset = true;
        aTimer.Enabled = true;
    }

    private static void OnTimedEvent(Object source, ElapsedEventArgs e)
    {
        Console.WriteLine("The Elapsed event was raised at {0:HH:mm:ss.fff}",
                          e.SignalTime);
    }
}
0
0
63
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы должны запомнить время начала и рассчитать разницу, чтобы увидеть затраченное время:

private static DateTime start;

private static void SetTimer()
{
    //
    // set the start time
    //
    start = DateTime.Now;

    ...
}

private static void OnTimedEvent(Object source, ElapsedEventArgs e)
{
    //
    // calculate the time spent
    //
    TimeSpan spent = DateTime.Now - start;

    Console.WriteLine($"The Elapsed event was raised at {spent.Hours}:{spent.Minutes:D2}:{spent.Seconds:D2}:{spent.Milliseconds:D3}");
}

Или, если требуется (и доступно) более высокое разрешение, может пригодиться System.Diagnostics.Stopwatch.

Corak 11.04.2018 13:47

Другие вопросы по теме