Форум программистов, компьютерный форум, киберфорум
Boost C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1

Linux. boost. Timer реагирует на системное время?

13.04.2012, 22:30. Показов 3595. Ответов 14
Метки нет (Все метки)

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

Есть: Debian, boost 1.49 и простой пример из доков буста

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void print(const boost::system::error_code& /*e*/)
{
  std::cout << "Hello, world!\n";
}
 
int main()
{
  boost::asio::io_service io;
 
  boost::asio::deadline_timer t(io, boost::posix_time::seconds(5));
  t.async_wait(print);
 
  io.run();
 
  return 0;
}
Все просто. Через 5 секунд произойдет "Hello, world!".
А теперь запустим программку и переведем время на минуту назад... "Hello, world!". мы не увидим.
Далее еще простой пример:
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
#include <boost/thread.hpp>
 
using namespace std;
 
int main()
{
    while(true) {
        std::cout << "Tick\n";
        boost::this_thread::sleep( boost::posix_time::milliseconds(1000));
    }
}
Видим
Code
1
2
3
4
Tick
Tick
Tick
...
Но если перевести время, то цикл останавливается.
Причем если использовать системные sleep или nanosleep, то все в порядке.

Так вот вопрос: такое дебильное поведение таймеров в бусте - это норма?
Это как-то обходится или писать костыли?
PS: проверьте кто-нибудь это поведение под Win пожалуйста.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.04.2012, 22:30
Ответы с готовыми решениями:

системное время Linux SuSE
Привет всем, может кто сталкивался с проблемой скачкообразного изменения времени на VMware Linux? Дело в том, что система очень...

Ввести время и от него отнять системное время
Необходимо ввести время и от него отнять системное время,необходимо сделать так Введите часы : 17 минуты : 00 и результат к примеру...

Системное время
Ребята, делаю программку дни рождения и хочу, чтоб меня оповещала программа, когда будет тому или иному человеку день рождения. Создал...

14
Каратель
Эксперт С++
6610 / 4029 / 401
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
14.04.2012, 01:41
Цитата Сообщение от villu Посмотреть сообщение
Все просто. Через 5 секунд произойдет "Hello, world!".
А теперь запустим программку и переведем время на минуту назад... "Hello, world!". мы не увидим.
boost 1.47 под Вин7, наблюдаю тоже самое
1
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
14.04.2012, 09:16
так и не понял, что ТС`а не устраивает)
ладно, если бы на оборот.
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
14.04.2012, 10:15
Цитата Сообщение от niXman Посмотреть сообщение
так и не понял, что ТС`а не устраивает)
ТС'а не устраивает нелогичное поведение. Если сказали ждать 5 секунд - надо ждать 5 секунд. Т.е. Си'шные функции типа sleep выполняют спячку через ядро, которое отслеживает изменения времени в системном таймере (ну или по каким-то другим алгоритмам отслеживает интервал). В boost'е, судя по всему, просто запоминается текущее время, прибавляется 5 секунд и результат запоминается. Далее постоянно через какой-то интервал идёт опрос системного таймера на предмет достижения заданного абсолютного времени

Если ты автору скажешь, как повторить поведение sleep'а в boost'е, то он, судя по всему, будет безмерно счастлив
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
14.04.2012, 10:19  [ТС]
не устраивает то, что при изменении системных часов все дедлайн-таймеры идут на погост (как клиент/сервер поведет себя при переводе на летнее/зимнее время?).
Да и ситуация со sleep мне кажется просто ненормальной.
В обоих системах (Win и Linux) Sleep и sleep(nanosleep) не зависят от системных часов.
элементарный alarm тоже не зависит.
В системах win/lin/macos/***bsd есть варианты написать такие дл-таймеры не прибивая их к текущему времени.

Вопрос в том имеется ли в бусте вариант это обойти? либо писать врапперы для разных систем?
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
14.04.2012, 10:34
villu, asio.deadline_timer для ожиданий использует select(). проверь описанное тобою поведение с селектом.
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
14.04.2012, 10:44  [ТС]
C++
1
2
3
4
5
6
7
8
9
int main( )
{
    timeval tv = {0};
    while(1) {
        tv.tv_sec = 1;
        select(0, 0, 0, 0, &tv);
        std::cout << "Select\n";
    }
}
Этот код работает ожидаемо, независимо от смены времени.
Да и с чего бы ему работать по другому?
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
14.04.2012, 10:46
минутку...
еще раз объясни: сишные функции sleep/nanosleep после взвода, и при переводе локального времени, ожидают положенное им время и не реагируют на изменение времени?


Цитата Сообщение от villu Посмотреть сообщение
(как клиент/сервер поведет себя при переводе на летнее/зимнее время?)
вообще, сервера работают по UTC, как правило.
0
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
14.04.2012, 10:51  [ТС]
сишные функции sleep/nanosleep после взвода, и при переводе локального времени, ожидают положенное им время и не реагируют на изменение времени?
да.
вообще, сервера работают по UTC, как правило.
да, но "если что-то может произойти, оно происходит". И как с клиентами быть?
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
14.04.2012, 10:57
Цитата Сообщение от villu Посмотреть сообщение
как с клиентами быть?
перерасчет времени для клиента происходит на клиенте с учетом его локали.

в общем понял проблему. сейчас пороюсь...

Добавлено через 2 минуты
кстати, кто знает, как используя только консольные утилиты можно переводить время? для тестов.
1
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
14.04.2012, 11:14
Цитата Сообщение от niXman Посмотреть сообщение
кто знает, как используя только консольные утилиты можно переводить время? для тестов.
date же, не?
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
14.04.2012, 11:34
>$ sudo date --set="2012-04-14 11:12:42"

Добавлено через 21 секунду
fasked, да, нагуглил уже.

Добавлено через 1 минуту
villu, да, проверил с boost::this_thread::sleep(). если переводишь время вперед - все работает как надо. если назад - зависон.

Добавлено через 16 минут
проблема с boost::this_thread::sleep() лечится так: boost::this_thread::sleep_for( boost::chrono::milliseconds(1000) );

но все равно попытаюсь понять почему оно так...
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
14.04.2012, 12:35
Цитата Сообщение от niXman Посмотреть сообщение
сишные функции sleep/nanosleep после взвода, и при переводе локального времени, ожидают положенное им время и не реагируют на изменение времени?
Да. Потому что эти функции являются обёрткой для системных вызовов. Т.е. вся начинка выполняется строго в ядре ОС, которое всё знает про время
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
14.04.2012, 14:58
villu, по поводу asio таймеров, вот что ответили: https://sourceforge.net/mailar... d=29128185
1
204 / 205 / 16
Регистрация: 06.08.2011
Сообщений: 600
Записей в блоге: 1
14.04.2012, 15:37  [ТС]
во! Сейчас порою. Но похоже, то, что нужно. Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.04.2012, 15:37
Помогаю со студенческими работами здесь

Системное время
Добрый вечер. Интересует работа строк: mov ax,es: и mov ax,es: В ax заносится системное время для es:. А для es: системное время +5 чего?...

Системное время
Как изменить системное время . Программа должна синхронизировать системное время по GPS, Важно -- Win7 SetSystemTime(tST); - не...

Системное время
Здравствуйте! Проблема такая: У нас в организации своя локальная сеть. Есть некий пользователь, его системное время показывает на 9...

Системное время
Не могу понять почему возвращает неправильно часы, хотя минуты показывает верно, подскажите в чем подвох procedure...

Системное время
Доброго всем дня! Собственно вопрос: Есть ли возможность узнать программным путем, было ли изменено системное время. Благодарю...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru