Russian Qt Forum
Май 17, 2024, 15:01 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: Задержка после QThread()::start()  (Прочитано 2515 раз)
Гурман
Гуру общения
******
Offline Offline

Сообщений: 1442

Qt 2.2, 3.3, 4.5, 4,7, 4.8, 5.3, 5.6, 5.9, 5.12


Просмотр профиля
« : Июль 16, 2015, 21:40 »

Заметил, что иногда между вызовом QThread::start() и входом в её run() возникает задержка. Возможно она возникает всегда, но коротко, а иногда она довольно заметна, где-то порядка 200 мс, может даже до полсекунды. Кто-нибудь разбирался, с чем это связано? Это влияние ОС, или внутренние особенности самого Qt? Наверно существенно, что я это заметил, когда не одна нить стартует, а несколько (5 в реальности).
« Последнее редактирование: Июль 16, 2015, 21:45 от Гурман » Записан

2^7-1 == 127, задумайтесь...
Old
Джедай : наставник для всех
*******
Offline Offline

Сообщений: 4349



Просмотр профиля
« Ответ #1 : Июль 16, 2015, 21:49 »

Стартуют несколько нитей. Сначала выполняется run первой нити, по истечении кванта выполняем run второй, потом третьей и т.д. Пока начнет выполняться run пятой - проходит какое-то время.
А заметно это становиться, наверное, тогда, когда ядро находит чем загрузить процессор помима вашего процесса.
« Последнее редактирование: Июль 16, 2015, 21:57 от Old » Записан
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.061 секунд. Запросов: 19.