C++ chrono

2021. 3. 16. 00:13·SW개발/C++
반응형

chrono

  • <chrono> 라이브러리

    • C++11

    • 실행 시간 측정(Run Time Measurement)에 사용되며, 시간을 비교적 정밀하게 측정할 수 있다.

    #include <iostream>
    #include <vector>
    #include <algorithm>
    #include <random>
    #include <chrono>
    
    using namespace std;
    
    class Timer
    {
      using clock_t = std::chrono::high_resolution_clock;
      using second_t = std::chrono::duration<double, std::ratio<1>>;
    
      std::chrono::time_point<clock_t> start_time = clock_t::now();
    
    public:
      void elapsed()
      {
        std::chrono::time_point<clock_t> end_time = clock_t::now();
    
        std::cout << std::chrono::duration_cast<second_t>(end_time - start_time).count() << std::endl;
      }
    };
    
    int        main()
    {
      random_device    rnd_device;
      mt19937            mersenne_engin{ rnd_device() };
    
      vector<int>        vec(100000);
      for (size_t i = 0; i < vec.size(); ++i)
        vec[i] = i;
    
      std::shuffle(begin(vec), end(vec), mersenne_engin);
    
      /*for (auto& e : vec) cout << e << ' ';
      cout << endl;*/
    
      Timer timer;
    
      std::sort(begin(vec), end(vec));
    
      timer.elapsed();
    
      /*for (auto& e : vec) cout << e << ' ';
      cout << endl;*/
    }
반응형
저작자표시 (새창열림)

'SW개발 > C++' 카테고리의 다른 글

C++ 오버로딩 (Overloading)  (0) 2021.03.16
C++ 따라하며 배우는 C++ 9장  (0) 2021.03.16
C++ Nested Types  (0) 2021.03.16
C++ 익명 객체 (Anonymous Class)  (0) 2021.03.16
C++ friend  (0) 2021.03.16
'SW개발/C++' 카테고리의 다른 글
  • C++ 오버로딩 (Overloading)
  • C++ 따라하며 배우는 C++ 9장
  • C++ Nested Types
  • C++ 익명 객체 (Anonymous Class)
Caniro
Caniro
  • Caniro
    Minimalism
    Caniro
  • 전체
    오늘
    어제
    • 전체보기 (319)
      • SW개발 (268)
        • Java Spring (6)
        • C++ (186)
        • Python (21)
        • Linux (16)
        • 알고리즘 (13)
        • Git (4)
        • Embedded (1)
        • Raspberrypi (9)
        • React (3)
        • Web (2)
        • Windows Device Driver (6)
      • IT(개발아님) (46)
        • Windows (26)
        • MacOS (7)
        • Utility (11)
      • 챗봇 짬통 (0)
      • 일상 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    windows
    KakaoTalk
    logi options
    SunOS 5.1
    spring
    맥북 카카오톡 알림 안뜸
    dism
    unix
    Workspace
    알림
    그림판
    EXCLUDE
    윈도우 명령어
    제외
    vscode
    Windows 11
    java
    시스템 복구
    백기선
    로지텍 마우스 제스처
    SFC
    Solaris 10
    스프링 프레임워크 핵심 기술
    citrix workspace
    윈도우
    MacOS
    스프링
    mspaint
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Caniro
C++ chrono
상단으로

티스토리툴바