crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

Iron Bug
  опции профиля:
сообщение 25.2.2010, 20:16
Сообщение #1


Профессионал
*****

Группа: Модератор
Сообщений: 1611
Регистрация: 6.2.2009
Из: Yekaterinburg
Пользователь №: 533

Спасибо сказали: 219 раз(а)




Репутация:   12  


Ухх, как мне сегодня хочется купить значок " я ненавижу мелкософт!". Сегодня - особенно.
Итак, дело было так: сижу, пишу сложную консольную софтину, которая в риалтайме мониторит состояние железа и ведёт логи. Софтина многопоточная, главный поток запускает все остальные, выводит на экран добропорядочную строку "Для выхода нажмите Enter" и ждёт (getchar()), пока пользователю надоест смотреть в чёрный экран. По нажатию Enter главный поток оживает, сообщает всем остальным, что пора совершить суицид, выводит на экран пару строк о завершении и умирает сам.
Так вот....
Софтину желательно запускать в риалтайме. Я, понятное дело, не мудрствуя лукаво, состряпала батник такого содержания:
start /REALTIME CMD /C Foo.exe

(где Foo,exe - моя замечательная софтина)
Однако, при запуске из консольного окна этот батник делал вот что: порождал ещё одно окно, в котором выполнял всю прогу и я не видела, что там в конце выводится на экран (а мне для отладки надо было видеть, что всё завершилось нормально). Мне это не понравилось, я быстренько через help посмотрела, что можно ему указать опцию /B - типа, чтобы дополнительное окно не открывалось, а вывод был в ту же консоль, где запущен батник. Поставив эту /B в свой батник
start /REALTIME /B CMD /C Foo.exe

я стала ковыряться с кодом, забыв (о горе!) про эту мелкую, но, как выяснилось, коварную опцию.
Скомпилировав прогу, я её запустила через батник. Проверив, что железо работает как надо, нажала Enter. Засады я не ожидала. Прога как будто завершилась (появилось стандартное приглашение системы), но... итоговой строки от своей софтины я не увидела. Более того, к моему удивлению, процесс остался висеть в памяти и количество потоков даже не уменьшилось. Я убила процесс и принялась ковырять код, полагая, что от моих последних изменений как-то нарушилась синхронизация потоков и потоки мешают друг другу нормально завершиться (опыт многопоточного программирования тут сыграл плохую шутку).
Я КОВЫРЯЛА КОД ПОЧТИ ТРИ ЧАСА!!!! Три часа ценного рабочего времени я пыталась понять, почему процесс остаётся висеть в памяти и нормальное завершение не происходит. Пока я случайно не нажала Enter два раза.... и тут (о, чудо!) на экран (после строки приглашения системы!) вывалились "потерявшиеся" строки о завершении потоков и процесс благополучно завершился, уже по-настоящему. Кстати, при этом строка приглашения системы после последних сообщений программы в консоли не появилась - она появлялась только после третьего нажатия Enter'а, хотя ввод команд в консоли и без неё работал.
ЕЩЁ ЧАС Я ПЫТАЛАСЬ ПОНЯТЬ, ПОЧЕМУ ТАК. Пока не вспомнила про маленькую гадкую опцию /B. Убрав которую, я моментально получила нормально работающую программу.
С работы я вышла, громко кроя мелкософт самыми непотребными словами.
Так что будьте бдительны, господа, и не теряйте своё драгоценное время! Я уже наступила на грабли и предупреждаю, что они там есть! :)

Сообщение отредактировал Iron Bug - 25.2.2010, 20:39
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
Litkevich Yuriy
  опции профиля:
сообщение 26.2.2010, 4:29
Сообщение #2


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(Iron Bug @ 26.2.2010, 0:58) *
я уже который год бомбардирую всех идеей перехода на линь.
а почему не рилтаймОСь, QNX какой-нибудь? Когда я работал в Тюменьпромгеофизике, там для некоторых целей его использовали.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Ответить в данную темуНачать новую тему
Теги
Нет тегов для показа


1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0


RSS Рейтинг@Mail.ru Текстовая версия Сейчас: 22.7.2025, 5:13