私のmacbookproのブーストクロノライブラリvs1.51は、endTime --startTimeを差し引くと、負の時間を返します。時点を印刷すると、終了時刻がstartTimeよりも早いことがわかります。これはどのように起こりますか?
typedef boost::chrono::steady_clock clock_t;
clock_t clock;
// Start time measurement
boost::chrono::time_point<clock_t> startTime = clock.now();
short test_times = 7;
// Spend some time...
for ( int i=0; i<test_times; ++i )
{
xnodeptr spResultDoc=parser.parse(inputSrc);
xstring sXmlResult = spResultDoc->str();
const char16_t* szDbg = sXmlResult.c_str();
BOOST_CHECK(spResultDoc->getNodeType()==xnode::DOCUMENT_NODE && sXmlResult == sXml);
}
// Stop time measurement
boost::chrono::time_point<clock_t> endTime = clock.now();
clock_t::duration elapsed( endTime - startTime);
std::cout << std::endl;
std::cout << "Now time: " << clock.now() << std::endl;
std::cout << "Start time: " << startTime << std::endl;
std::cout << "End time: " << endTime << std::endl;
std::cout << std::endl << "Total Parse time: " << elapsed << std::endl;
std::cout << "Avarage Parse time per iteration: " << (boost::chrono::duration_cast<boost::chrono::milliseconds>(elapsed) / test_times) << std::endl;
私は別の時計を試しましたが、違いはありませんでした。
どんな助けでもいただければ幸いです!
編集:出力を追加するのを忘れました:
現在の時間:起動から1ナノ秒
開始時間:起動から140734799802912ナノ秒
終了時間:起動から140734799802480ナノ秒
合計解析時間:-432ナノ秒反復あたりの平均解析時間:0ミリ秒