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
  • 전체
    오늘
    어제
    • 전체보기 (321) N
      • SW개발 (269) N
        • Java Spring (6)
        • C++ (186)
        • Python (21)
        • Linux (16)
        • 알고리즘 (13)
        • Git (4)
        • Embedded (1)
        • Raspberrypi (9)
        • React (3)
        • Web (3) N
        • Windows Device Driver (6)
      • IT(개발아님) (47)
        • Windows (26)
        • MacOS (8)
        • Utility (11)
      • 챗봇 짬통 (0)
      • 일상 (2)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바