Я использую некоторый код для отчета о длительности задачи, используя std:: chrono:: high_resolution_clock... часть С++ 0x.
Я могу успешно скомпилировать функции С++ 0x в eclipse cdt, используя флаг -gnu ++ 0x. Несмотря на успешную компиляцию, редактор, похоже, не знал о С++ 0x, то есть отображал ошибки для любых функций С++ 0x в моем коде. Я решил, что добавив флаг -gnu ++ 0x в мои параметры поиска проекта. Примечание: не отображается исправлено, пока вы не выполните компиляцию и не перестройте индекс...
-E -P -v -dD "$ {plugin_state_location}/specs.cpp" -std = gnu ++ 0x
У меня все еще есть одна последняя ошибка редактора, которую я не могу избавиться от "Symbol" duration_cast "не может быть разрешен" (у меня был рис, но новые пользователи не могут публиковать фотографии)
У кого-нибудь есть идеи о том, как это исправить? Вот код:
#ifndef _scoped_timer_h_
#define _scoped_timer_h_
#include <iostream>
#include <chrono>
#include "boost/noncopyable.hpp"
#include "boost/format.hpp"
using namespace std::chrono;
// Utility class for timing and logging rates
// (ie "things-per-second").
// NB _any_ destructor invokation (including early return
// from a function or exception throw) will trigger an
// output which will assume that whatever is being measured
// has completed successfully and fully.
class scoped_timer : boost::noncopyable
{
public:
scoped_timer(
const std::string& what,
const std::string& units,
double n
)
:_what(what)
,_units(units)
,_how_many(n)
,_start(high_resolution_clock::now())
{}
~scoped_timer() {
high_resolution_clock::time_point stop = high_resolution_clock::now();
const double t = 1e-9 * duration_cast<nanoseconds>(stop-_start).count();
std::cout << (
boost::format(
"%1%: %|2$-5.3g| %|3$|/s (%|4$-5.3g|s)"
) % _what % (_how_many/t) % _units % t
) << std::endl;
}
private:
const std::string _what;
const std::string _units;
const double _how_many;
const high_resolution_clock::time_point _start;
};
#endif