C++11 chrono:给time_point对象赋值

3

我正在尝试使用chrono来测量某个函数的时间,所以我的代码看起来像这样:

#include <chrono>
#include <iostream>

using namespace std;

void doSomething()
{
  //code goes here
}

int main()
{
  chrono::time_point<chrono::system_clock> start,end;
  start=chrono::system_clock::now;
  doSomething();
  end=chrono::system_clock::now;
}

基本上,我正在遵循来自cppreference的代码示例。

问题在于,我在start=chrono::system_clock::nowend=chrono::system_clock::now处都遇到以下错误。

error: no match for 'operator=' (operand types are 
'std::chrono::time_point<std::chrono::system_clock, 
std::chrono::duration<long long int, std::ratio<1ll, 1000000000ll> > >'
and 'std::chrono::system_clock::time_point()noexcept (true) 
{aka std::chrono::time_point<std::chrono::system_clock,
std::chrono::duration<long long int, std::ratio<1ll, 1000000000ll> > >()noexcept (true)}')

我还尝试将chrono::time_point<chrono::system_clock> start,end;更改为chrono::system_clock::time_point start,end;。错误几乎相同:
error: no match for 'operator=' (operand types are
'std::chrono::system_clock::time_point 
{aka std::chrono::time_point<std::chrono::system_clock,
std::chrono::duration<long long int, std::ratio<1ll, 1000000000ll> > >}'
and 'std::chrono::system_clock::time_point()noexcept (true) 
{aka std::chrono::time_point<std::chrono::system_clock,
std::chrono::duration<long long int, std::ratio<1ll, 1000000000ll> > >()noexcept (true)}')

我正在使用Qt 5.1.0(32位)和MinGW 4.8 32位作为编译器。我还需要在我的.pro文件中添加编译器标志以支持c++11,方法是添加QMAKE_CXXFLAGS+=-std=c++11

1个回答

4

使用 () 来调用 system_clock::now

  chrono::time_point<chrono::system_clock> start,end;
  start=chrono::system_clock::now(); //<-- Fix

 doSomething();
  end=chrono::system_clock::now();  //<-- Fix

经过时间计算为:

  auto duration = end - start;
  std::cout << chrono::duration <double, std::milli> (duration).count()
            << " ms" << std::endl;

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接