Scroll to navigation

std::thread::native_handle(3) C++ Standard Libary std::thread::native_handle(3)

NAME

std::thread::native_handle - std::thread::native_handle

Synopsis


native_handle_type native_handle(); (since C++11)
(not always present)


Returns the implementation defined underlying thread handle.

Parameters


(none)

Return value


implementation defined handle type representing the thread.

Exceptions


May throw implementation-defined exceptions.

Example


Uses native_handle to enable realtime scheduling of C++ threads on a POSIX system

// Run this code


#include <thread>
#include <mutex>
#include <iostream>
#include <chrono>
#include <cstring>
#include <pthread.h>


std::mutex iomutex;
void f(int num)
{
std::this_thread::sleep_for(std::chrono::seconds(1));


sched_param sch;
int policy;
pthread_getschedparam(pthread_self(), &policy, &sch);
std::lock_guard<std::mutex> lk(iomutex);
std::cout << "Thread " << num << " is executing at priority "
<< sch.sched_priority << '\n';
}


int main()
{
std::thread t1(f, 1), t2(f, 2);


sched_param sch;
int policy;
pthread_getschedparam(t1.native_handle(), &policy, &sch);
sch.sched_priority = 20;
if (pthread_setschedparam(t1.native_handle(), SCHED_FIFO, &sch)) {
std::cout << "Failed to setschedparam: " << std::strerror(errno) << '\n';
}


t1.join(); t2.join();
}

Output:


Thread 2 is executing at priority 0
Thread 1 is executing at priority 20

2022.07.31 http://cppreference.com