C/C++编程:计算cpp程序运行时间(ms)(单线程&&多线程)

1059 篇文章 285 订阅

计算cpp程序运行时间

需要c++11支持

#include <chrono>

auto start = std::chrono::system_clock::now();
//do something
auto end = std::chrono::system_clock::now();
auto elapsed = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);
std::cout << elapsed.count() <<"ms" << '\n';

#include <time.h>

time_t begin_t  = clock();
// to do 
time_t finish_t = clock();

cout<<"it cost " << (double )(finish_t - begin_t )/CLOCKS_PER_SEC <<" s"<<endl;

准确获取多线程序运行时间

1、acl_meter_time.c


#include <lzma.h>
#include <zconf.h>
#include <pthread.h>
#include <malloc.h>
#include <sys/time.h>

static void free_tls(void *ptr)
{
    free(ptr);
}

static pthread_key_t  once_key;
static void once_init(void){
    pthread_key_create(&once_key, free_tls);
}
static pthread_once_t once_control = PTHREAD_ONCE_INIT;
static void *tls_calloc(size_t len){
    void *ptr;

    pthread_once(&once_control, once_init);
    ptr = pthread_getspecific(once_key);
    if(ptr == NULL){
        ptr = calloc(1, len);
        pthread_setspecific(once_key, ptr);
    }
    return ptr;
}

typedef struct {
    struct timeval stamp;
    int   init_done;
} METER_CTX_T;
double acl_meter_time(const char *filename, int line, const char *info){
    struct timeval now;
    double  f;
    METER_CTX_T *ctx = tls_calloc(sizeof(METER_CTX_T));

    if(ctx->init_done == 0){
        ctx->init_done = 1;
        gettimeofday(&ctx->stamp, NULL);
    }

    gettimeofday(&now, NULL);
    now.tv_usec -= ctx->stamp.tv_usec;
    if (now.tv_usec < 0) {
        --now.tv_sec;
        now.tv_usec += 1000000;
    }
    now.tv_sec -= ctx->stamp.tv_sec;

    f = now.tv_sec * 1000.0 + now.tv_usec/1000.0;
    if (info)
        printf("tid=%lu, %s(%d), %s: time inter = %8.3f ms\r\n",
               (unsigned long) pthread_self(), filename, line, info, f);
    else
        printf("tid=%lu, %s(%d): time inter = %8.3f ms\r\n",
               (unsigned long) pthread_self(), filename, line, f);

    gettimeofday(&ctx->stamp, NULL);
    return (f);
}

2、acl_meter_time.h

#pragma once


double acl_meter_time(const char *filename, int line, const char *info);

#define	ACL_METER_TIME(info)	acl_meter_time(__FILE__, __LINE__, info)

3、如何使用

#include <stdio.h>
#include <sys/time.h>
#include <zconf.h>
#include <pthread.h>
#include "stdlib.h"


#include "acl_meter_time.h"

void *thr_fn1(void *arg)
{
    ACL_METER_TIME(NULL);
    usleep(1000);
    ACL_METER_TIME(NULL);
    printf("thread 1 returning\n");
    return((void *)1);
}

int main(void)
{
    ACL_METER_TIME(NULL);
    int			err;
    pthread_t	tid1, tid2;
    void		*tret;
    err = pthread_create(&tid1, NULL, thr_fn1, NULL);
    if (err != 0){
        fprintf(stderr, "can't create thread 1");
        exit(err);
    }
    err = pthread_join(tid1, &tret);
    if (err != 0){
        fprintf(stderr, "can't join with thread 1");
        exit(err);
    }


    usleep(1000);
    ACL_METER_TIME(NULL);


    return 0;
}



在这里插入图片描述

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 C/C++ 程序中用 CreateThread 函数创建新线程播放音乐与主线程同时运行的方法如下: 1. 首先你需要包含 Windows 头文件 `Windows.h`。 2. 然后你需要声明一个线程函数,并指定线程函数的类型为 `DWORD WINAPI`。线程函数的参数是一个指向 void 类型的指针,你可以在这个指针所指向的内存中存储一些需要在线程中使用的数据。 3. 然后你可以使用 CreateThread 函数创建一个新线程,并将线程函数的地址作为参数传入。 下面是一个示例代码: ```cpp #include <Windows.h> DWORD WINAPI PlayMusic(LPVOID lpParameter) { // 在这里播放音乐 return 0; } int main() { // 创建新线程 HANDLE hThread = CreateThread(NULL, 0, PlayMusic, NULL, 0, NULL); if (hThread == NULL) { // 创建线程失败 return -1; } // 等待线程结束 WaitForSingleObject(hThread, INFINITE); return 0; } ``` 在这个示例中,我们在主线程中创建了一个新线程,并让新线程执行 PlayMusic 函数,在这个函数中播放音乐。主线程在调用 CreateThread 函数后会继续往下执行,并调用 WaitForSingleObject 函数等待新线程结束。这样主线程和新 ### 回答2: 在C/C++程序中,可以使用`CreateThread`函数来创建新线程来播放音乐,同时保持主线程的运行。下面是一个基本示例: 首先,需要包含Windows.h头文件,然后使用`CreateThread`函数来创建新线程。同时,我们需要在新线程中实现音乐播放的功能。下面是一个示例代码: ```c #include <Windows.h> #include <stdio.h> #include <stdlib.h> DWORD WINAPI PlayMusic(LPVOID lpParam) { // 在此处实现音乐播放的具体逻辑 printf("新线程播放音乐\n"); Sleep(5000); // 假设音乐播放需要5秒钟 // 结束线程 ExitThread(0); } int main() { HANDLE hThread; DWORD threadId; // 创建新线程 hThread = CreateThread(NULL, 0, PlayMusic, NULL, 0, &threadId); if (hThread == NULL) { printf("创建线程失败\n"); return 1; } // 在此处编写主线程的其他逻辑 printf("主线程继续运行\n"); Sleep(2000); // 假设主线程运行需要2秒钟 // 等待新线程结束 WaitForSingleObject(hThread, INFINITE); return 0; } ``` 在上述代码中,`PlayMusic`函数是新线程的入口函数,在该函数内实现了音乐播放的具体逻辑。主线程继续运行,并在某个时刻使用`WaitForSingleObject`函数等待新线程的结束。 需要注意的是,由于C/C++程序是单线程的,必须依赖于Windows提供的多线程机制来实现同时运行多个任务。因此,我们需要使用`CreateThread`函数创建新线程。 此外,为了确保线程安全,需要适当使用同步机制如互斥量(Mutex)等来保护共享资源,以防止多线程访问冲突。在具体的音乐播放逻辑中,可能需要考虑这些方面。 ### 回答3: 使用CreateThread函数创建新线程可以实现在C/C++程序中同时播放音乐和运行主线程。以下是具体步骤: 1. 首先,将音乐播放功能封装在一个函数中,例如"playMusic"。这个函数会负责打开音乐文件、播放音乐以及关闭文件等操作。 2. 在主线程中,使用CreateThread函数创建一个新线程,并传入指向playMusic函数的指针作为参数。例如: ```c++ HANDLE hThread; hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)playMusic, NULL, 0, NULL); ``` 这里,第一个参数为线程安全属性,默认设置为NULL;第二个参数为栈的大小,设置为0表示使用默认大小;第三个参数为线程函数的指针,将playMusic函数的地址强制转换为LPTHREAD_START_ROUTINE类型;第四个参数为传递给线程函数的参数,没有额外参数则设置为NULL;最后两个参数为线程的创建选项和线程id,设置为NULL。 3. 然后,主线程可以继续执行其他任务,不受音乐播放的影响。 4. 为了保证主线程不会在音乐播放结束之前退出,可以在主线程中调用WaitForSingleObject函数等待新线程的结束。 ```c++ WaitForSingleObject(hThread, INFINITE); ``` 这里的hThread为新线程的句柄,INFINITE表示等待无限长时间,直到新线程结束。 通过以上步骤,就可以实现在C/C++程序中使用CreateThread函数创建新线程并同时播放音乐和运行主线程。新线程会负责音乐播放,而主线程可以继续执行其他任务,直到音乐播放结束。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值