次に示すのは、スレッドをタイマーでラップするテスト クラスの実装です。奇妙なことに、期限を 500 ミリ秒に設定すると機能しますが、1000 ミリ秒に設定すると機能しません。私は何を間違っていますか?
#include "TestTimer.hpp"
#include "../SysMLmodel/Package1/Package1.hpp"
TestTimer::TestTimer(){
thread = boost::thread(boost::bind(&TestTimer::classifierBehavior,this));
timer = new boost::asio::deadline_timer(service,boost::posix_time::milliseconds(1000));
timer->async_wait(boost::bind(&TestTimer::timerBehavior, this));
};
TestTimer::~TestTimer(){
}
void TestTimer::classifierBehavior(){
service.run();
};
void TestTimer::timerBehavior(){
std::cout<<"timerBehavior\r";
timer->expires_at(timer->expires_at() + boost::posix_time::milliseconds(1000));
timer->async_wait(boost::bind(&TestTimer::timerBehavior,this));
}
更新 1 プログラムが動かなくなったことに気付きました (または、少なくともコンソールの標準出力が数秒間、約 30 秒間)、多くの「timerBehavior」文字列が、どこかにキューに入れられたかのように一緒に出力されます。