Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I measure CPU time of a specific set of threads?

I run C++ program in Linux.

There are several threads pool (for computation, for io, for ... such things).

The system call clock() gives me a way to measure the CPU time spent by all the CPU cores for the process.

However, I want to measure the CPU time spent only by the threads in the computation threads pool.

How can I achieve it?

Thanks :D

like image 447
syko Avatar asked Jul 05 '17 02:07

syko


Video Answer


1 Answers

To get CPU clock ID of every thread you can use: pthread_getcpuclockid and using this CPU clock ID you can retrieve the current thread CPU time using: clock_gettime.

Following is the sample code to demonstrate the same:

struct timespec currTime;
clockid_t threadClockId;

//! Get thread clock Id
pthread_getcpuclockid(pthread_self(), &threadClockId);
//! Using thread clock Id get the clock time
clock_gettime(threadClockId, &currTime);
like image 191
Hemant Gangwar Avatar answered Sep 23 '22 18:09

Hemant Gangwar