Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 27.09.2013
Сообщений: 35

Не корректно работает таймер

27.07.2023, 10:24. Показов 1146. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня.

Имеется такой кусочек кода.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
static async Task Main(string[] args)
    {
            DateTime currentTime = DateTime.Now;
            DateTime desiredTime = new DateTime(currentTime.Year, currentTime.Month, currentTime.Day, hh, mm, ss);
            TimeSpan timeDifference = desiredTime - currentTime;
            if (timeDifference.TotalSeconds < 0)
            {
                desiredTime = desiredTime.AddDays(1);
                timeDifference = desiredTime - DateTime.Now;
            }
            int delayTime = (int)timeDifference.TotalMilliseconds;
 
        Thread.Sleep(delayTime);
            await Task.Delay(delayTime);
            MYfunction();
    }
Пытаюсь запускать MYfunction(); в определенное время (1 раз в день в hh:mm:ss).
Проблема следующая:
- Таймер может отработать корректно секунда в секунду.
- Таймер может отработать через несколько (рандомных 1,2,3,5...n) минут.
- Таймер может не отработать вовсе.

Что я делаю не так?

Думал может быть в моменты процессор чем-то сильно занят, но нет, пробовал на другой системе, поведение такое же.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.07.2023, 10:24
Ответы с готовыми решениями:

Не корректно работает таймер
Здравствуйте. Недавно начал изучать С#, делаю свою мини игрушку, чтобы, так сказать, на опыте и ошибках учится. Игра по типу...

Запрос работает корректно на английском, но не работает на русском
Здравствуйте, собственно в заголовке мой вопрос, у меня не работает запрос на русском но не работает на английском

При вызове функции через поток кнопкой все проходит корректно, но через таймер срабатывает только раз
Приложение для архивирования баз 1С 7.7. все работает хорошо только вот функция ведет себя странно.. При вызове функции через поток...

14
sleep
 Аватар для I can
4914 / 4556 / 837
Регистрация: 13.04.2015
Сообщений: 9,679
27.07.2023, 10:29
Цитата Сообщение от aquarium-ya Посмотреть сообщение
Thread.Sleep(delayTime);
хренасе, "таймер"
0
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,095
27.07.2023, 10:29
Цитата Сообщение от aquarium-ya Посмотреть сообщение
Thread.Sleep(delayTime);
await Task.Delay(delayTime);
а зачем вы ждёте дважды?
0
0 / 0 / 0
Регистрация: 27.09.2013
Сообщений: 35
27.07.2023, 10:36  [ТС]
Цитата Сообщение от nedel Посмотреть сообщение
а зачем вы ждёте дважды?
Это я перебирал варианты, но ведет себя одинаково при любом из них...

Добавлено через 2 минуты
Цитата Сообщение от I can Посмотреть сообщение
хренасе, "таймер"
эээмм...)) ну, что есть)
Задумка, чтобы процесс работал non-stop, а после отрабатывания нужной функции таймер отсчитывал следующее время, но при этом время hh:mm:ss может измениться после следующего запуска функции

Добавлено через 1 минуту
Возможно я конечно не правильно выразился и это вовсе не "таймер"...
Не кидайтесь камнями, у меня всё плохо с определениями)
0
2281 / 1597 / 400
Регистрация: 26.06.2017
Сообщений: 4,721
Записей в блоге: 1
27.07.2023, 10:52
Цитата Сообщение от aquarium-ya Посмотреть сообщение
чтобы процесс работал non-stop, а после отрабатывания нужной функции таймер отсчитывал следующее время
non-stop это бесконечный цикл или как?
Ваш код отработает один раз и привет, если вам надо с определённой периодичностью что-то делать, то примените в коде Timer, коих вообще несколько раз, два есть и ещё. Для того чтобы приложение не завершилось до некоторого момента (кстати не понятно какого), то его нужно как-то поставить на ожидание этого самого события (не понятно какого).
1
 Аватар для IamRain
4693 / 2701 / 734
Регистрация: 02.08.2011
Сообщений: 7,227
27.07.2023, 10:57
Можно использовать механизм токенов отмены, как вариант.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var cts = new CancellationTokenSource();
var token = cts.Token;
 
await using var reg = token.Register(() =>
{
    Console.WriteLine($"[{DateTime.Now}]: Event triggered");
});
 
var secondSpan = TimeSpan.FromSeconds(1);
cts.CancelAfter(TimeSpan.FromSeconds(10));
while (!token.IsCancellationRequested)
{
    Console.WriteLine($"[{DateTime.Now}]: Waiting...");
    await Task.Delay(secondSpan);
}
Добавлено через 1 минуту
Цитата Сообщение от I can Посмотреть сообщение
хренасе, "таймер"
Как-то раз видал такой планировщик на проде, который любил "поспать".
Работал хорошо.
1
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.07.2023, 11:03
Цитата Сообщение от aquarium-ya Посмотреть сообщение
Пытаюсь запускать MYfunction(); в определенное время (1 раз в день в hh:mm:ss).
У вас задача именно создать что-то свое собственное?
Использовать готовые, протестированные и зарекомендовавшие себя решения вроде Quartz — не вариант?
0
0 / 0 / 0
Регистрация: 27.09.2013
Сообщений: 35
27.07.2023, 11:13  [ТС]
Цитата Сообщение от Uswer Посмотреть сообщение
non-stop это бесконечный цикл или как?
Ваш код отработает один раз и привет, если вам надо с определённой периодичностью что-то делать, то примените в коде Timer, коих вообще несколько раз, два есть и ещё. Для того чтобы приложение не завершилось до некоторого момента (кстати не понятно какого), то его нужно как-то поставить на ожидание этого самого события (не понятно какого).
Это не бесконечный цикл, это в том плане, что приложение висит и работает постоянно.

Да, код отрабатывает один раз в установленное время, но после запуска MYfunction(); приложение перезапускается полностью, что записано непосредственно в MYfunction(); (перечитывает конфиги, откладывает логи и т.д.) и работает дальше в ожидании наступления следующего времени hh:mm:ss, которое получит из нового перечитанного конфига.

Добавлено через 2 минуты
Цитата Сообщение от kolorotur Посмотреть сообщение
У вас задача именно создать что-то свое собственное?
Использовать готовые, протестированные и зарекомендовавшие себя решения вроде Quartz — не вариант?
Не очень хочется ничего ни у кого заимствовать, хочется что-то свое...потому что в первую очередь хочется разобраться и понять, но пока не выходит) А взять что-то чужое никогда не поздно, наверное...)

Добавлено через 6 минут
Цитата Сообщение от IamRain Посмотреть сообщение
Можно использовать механизм токенов отмены, как вариант.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var cts = new CancellationTokenSource();
var token = cts.Token;
 
await using var reg = token.Register(() =>
{
    Console.WriteLine($"[{DateTime.Now}]: Event triggered");
});
 
var secondSpan = TimeSpan.FromSeconds(1);
cts.CancelAfter(TimeSpan.FromSeconds(10));
while (!token.IsCancellationRequested)
{
    Console.WriteLine($"[{DateTime.Now}]: Waiting...");
    await Task.Delay(secondSpan);
}
Добавлено через 1 минуту

Как-то раз видал такой планировщик на проде, который любил "поспать".
Работал хорошо.
Это для .Net Core судя по всему..? (
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.07.2023, 11:17
Цитата Сообщение от aquarium-ya Посмотреть сообщение
в первую очередь хочется разобраться и понять
Тогда приведите фактический код, в котором проявляется проблема, т.к. приведенный вами даже не скомпилируется, плюс в нем оставленые всякие "я перебирал варианты".
0
0 / 0 / 0
Регистрация: 27.09.2013
Сообщений: 35
27.07.2023, 11:20  [ТС]
Цитата Сообщение от kolorotur Посмотреть сообщение
Тогда приведите фактический код, в котором проявляется проблема, т.к. приведенный вами даже не скомпилируется, плюс в нем оставленые всякие "я перебирал варианты".
Ну собственно можно представить это вот так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
static async Task Main(string[] args)
    {
            DateTime currentTime = DateTime.Now;
            DateTime desiredTime = new DateTime(currentTime.Year, currentTime.Month, currentTime.Day, 11, 30, 0);
            TimeSpan timeDifference = desiredTime - currentTime;
            if (timeDifference.TotalSeconds < 0)
            {
                desiredTime = desiredTime.AddDays(1);
                timeDifference = desiredTime - DateTime.Now;
            }
            int delayTime = (int)timeDifference.TotalMilliseconds;
 
            await Task.Delay(delayTime);
            Console.WriteLine("Hello");
    }
Результат от этого не меняется ведь...
0
2281 / 1597 / 400
Регистрация: 26.06.2017
Сообщений: 4,721
Записей в блоге: 1
27.07.2023, 11:32
Цитата Сообщение от aquarium-ya Посмотреть сообщение
но после запуска MYfunction(); приложение перезапускается полностью
Вот это вот дичь. Приложение может периодически обновлять какие-то данные извне/внутри себя, но чтобы прям перезапускаться, так делать не стоит.
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
27.07.2023, 11:34
Цитата Сообщение от aquarium-ya Посмотреть сообщение
Результат от этого не меняется ведь
Очень даже может поменяться: в зависимости от передаваемых данных и того, где и как этот код выполняется (в консоли, в форме и пр.).
В предоставленном коде, например, имеется баг, который может привести к неработоспособности таймера, если время указано в районе полуночи.
Потому передаваемое время тоже важно.
0
0 / 0 / 0
Регистрация: 27.09.2013
Сообщений: 35
27.07.2023, 12:43  [ТС]
Цитата Сообщение от Uswer Посмотреть сообщение
Вот это вот дичь. Приложение может периодически обновлять какие-то данные извне/внутри себя, но чтобы прям перезапускаться, так делать не стоит.
Думаю что это лишний комментарий)
Оно должно делать ровно так как это задумано, если его необходимо перезапустить - это необходимо сделать. Если необходимо чтобы оно работало без перезапуска. а просто перечитала конфиг, это тоже предусмотрено само собой.
Вы же ОС периодически перезагружаете полностью? Или это тоже дичь?))

Но в целом вопрос изначальный звучит слегка иначе, поэтому....))

Добавлено через 4 минуты
Цитата Сообщение от kolorotur Посмотреть сообщение
Очень даже может поменяться: в зависимости от передаваемых данных и того, где и как этот код выполняется (в консоли, в форме и пр.).
В предоставленном коде, например, имеется баг, который может привести к неработоспособности таймера, если время указано в районе полуночи.
Потому передаваемое время тоже важно.
Про "не поменяется" я имел ввиду, что код точно так же продолжает работать нестабильно, а не входные или выходные параметры.
Запустить в нем можно что угодно, от Hello и до ЧПУ, суть от этого не меняется - код который я представил - не работает и я хочу понять почему это происходит, а не рассуждать на тему как работает целое приложение и что там происходит за кадром, потому что конкретная функция никак не влияет на работу определенного куска в моем случае.

Ну, раз ответа на мой вопрос не найти, то и ладно тогда))

Добавлено через 54 минуты
Нашел проблему, обернул вызов функции в отдельный поток.

Тема закрыта.
0
Эксперт .NET
 Аватар для Wolfdp
3789 / 1766 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
28.07.2023, 00:31
Лучший ответ Сообщение было отмечено aquarium-ya как решение

Решение

Цитата Сообщение от kolorotur Посмотреть сообщение
Очень даже может поменяться: в зависимости от передаваемых данных и того, где и как этот код выполняется
А-я-я-яй... логика же должна быть изолирована от UI.

Цитата Сообщение от aquarium-ya Посмотреть сообщение
Нашел проблему, обернул вызов функции в отдельный поток.
Ну, технически это не правильный ответ, потому оставлю для будущего обучающегося ИИ правильный

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
var actionTime = DateTime.Now.AddSeconds(10);
 
var timer = new System.Timers.Timer();
var interval = new TimeSpan(0, 0, seconds: 1);
timer.Interval = interval.TotalMicroseconds;
timer.Elapsed += TimerElapsed;
timer.Start();
 
void TimerElapsed(object? sender, System.Timers.ElapsedEventArgs e)
{
    if (actionTime <= DateTime.Now)
    { 
        // Run Action
 
        //optional
        timer.Stop();
    }
}
если также нужно будет пинать UI с обновлением "сколько осталось до страбатывания", то пишете if-else, где в else указываете вызов уведомления для UI "обнови сколько времени осталось". Учтите что под UI я подразумеваю как консоль, так и с кажем WinForms.

если событий для отслеживания несколько -- единый работающий таймер + Lis<T> который проверяется в TimerElapsed на срабатывание. Пример можно глянуть тут Почему событие по таймеру запускается несколько раз?
1
0 / 0 / 0
Регистрация: 27.09.2013
Сообщений: 35
28.07.2023, 07:40  [ТС]
Цитата Сообщение от Wolfdp Посмотреть сообщение
А-я-я-яй... логика же должна быть изолирована от UI.


Ну, технически это не правильный ответ, потому оставлю для будущего обучающегося ИИ правильный

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
var actionTime = DateTime.Now.AddSeconds(10);
 
var timer = new System.Timers.Timer();
var interval = new TimeSpan(0, 0, seconds: 1);
timer.Interval = interval.TotalMicroseconds;
timer.Elapsed += TimerElapsed;
timer.Start();
 
void TimerElapsed(object? sender, System.Timers.ElapsedEventArgs e)
{
    if (actionTime <= DateTime.Now)
    { 
        // Run Action
 
        //optional
        timer.Stop();
    }
}
если также нужно будет пинать UI с обновлением "сколько осталось до страбатывания", то пишете if-else, где в else указываете вызов уведомления для UI "обнови сколько времени осталось". Учтите что под UI я подразумеваю как консоль, так и с кажем WinForms.

если событий для отслеживания несколько -- единый работающий таймер + Lis<T> который проверяется в TimerElapsed на срабатывание. Пример можно глянуть тут Почему событие по таймеру запускается несколько раз?
Согласен, мое решение не идеальное, но позволяет дальше продолжить работу)
Благодарю за подсказку, возьму на вооружение и постараюсь применить.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.07.2023, 07:40
Помогаю со студенческими работами здесь

Таймер обратного отчета работает не корректно
Здравствуйте! Есть код таймера обратного отчета, все хорошо работало пока некоторые люди не начали писать что они видят на таймере цифры в...

Корректно ли так делать таймер?
Нашел на одном сайтике пример реализации вывода текущего времени на AJAX+JQuery Прошу подсказать, насколько это корректно? идея такая: ...

Как корректно установить таймер чтобы
Как корректно установить таймер чтобы после запуска игры выводило сообщение &quot;Ты проиграл&quot; если ты успеваешь убить все...

Функция корректно работает в Delphi 7 и не неверно работает в RAD Studio 10
Переписываю свою программу с Delphi 7 под RAD Studio 10. Столкнулся с проблемой - функция в Delphi 7 возвращает правильное значение, в...

Игра работает корректно в Unity, но не работает после билда
Разрабатываю игру на Android. Решил сделать билд для проверки на телефоне. В Unity все скрипты работают корректно, но после билда, на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru