linux下多线程C++运行时间统计

本文探讨了在Linux环境下,使用`clock()`和`time()`函数在多线程中进行时间统计时遇到的问题。由于`clock()`在多线程中会导致CPU时钟时间误差较大,而`time()`记录的是系统时间,单位为秒,其结果更适用于多线程程序的计时。示例代码展示了这两个函数在多线程程序中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CMakeLists.txt

  • 下面所有的代码的CMakeLists.txt如下

  • cmake_minimum_required(VERSION 2.8)
    
    list(APPEND CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake/Modules)
    
    # else can not fin nullptr and so on.
    set (CMAKE_CXX_STANDARD 11)
    
    #project name
    project(thread_test)
    
    #debug
    set(CMAKE_BUILD_TYPE debug )
    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC -march=native -fopenmp -g2 -ggdb -lpthread")
    
    # thread_create
    set( EXE_NAME thread_create_test )
    set(APP_SRC thread_create.cpp)
    add_executable(${EXE_NAME} ${APP_SRC} )
    target_link_libraries(${EXE_NAME})

    clock

    • clock函数在ctime中,用于统计cpu时钟时间,在程序是单线程时,相对准确,但是如果开启多线程,则会出现很大误差。如下面的程序

      #include <iostream>
      #include <pthread.h>
      #include <unistd.h>
      
      #include <ctime>
      #include <unistd.h>
      #include <vector>
      
      using namespace std;
      
      void* thr
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值