Я хочу, чтобы поток ускорения заснул на несколько наносекунд. Следующий код является образцом, который компилируется без ошибок. Однако он не работает должным образом, и я не могу понять, почему.
#include <iostream>
#include <boost/thread.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/date_time.hpp>
//Building options:
//-DBOOST_DATE_TIME_POSIX_TIME_STD_CONFIG -lboost_date_time-mt -lboost_thread-mt
void replay()
{
boost::posix_time::time_duration time1, time2;
time1=boost::posix_time::seconds(3);
std::cout << boost::posix_time::to_simple_string(time1) << std::endl;
boost::this_thread::sleep(time1);
time2=boost::posix_time::nanoseconds(987654321);
std::cout << boost::posix_time::to_simple_string(time2) << std::endl;
boost::this_thread::sleep(time2);
}
int main(int argc, char* argv[])
{
boost::thread replaythread(replay);
replaythread.join();
return 0;
}
BOOST_DATE_TIME_POSIX_TIME_STD_CONFIG — это определение препроцессора, необходимое для работы с наносекундами (подробнее). Проблемы возникают, когда я устанавливаю параметр построения -DBOOST_DATE_TIME_POSIX_TIME_STD_CONFIG, тогда boost::this_thread::sleep не работает для любого posix::time_duration. Созданный поток использует весь ЦП, не спит и не обрабатывает оставшиеся инструкции. Если определение препроцессора удалено, поток может спать в течение любого периода времени, кроме boost::posix_time::nanoseconds. Программа использует некоторые переменные time_duration для хранения наносекунд, поэтому boost::this_thread::sleep не работает.
Спасибо вам большое за ваше время