std::thread::native_handle
De cppreference.com
<tbody>
</tbody>
native_handle_type native_handle(); |
(desde C++11) (opcional) |
|
Devuelve el identificador de hilo/subproceso subyacente definido por la implementación.
Parámetros
(Ninguno)
Valor de retorno
Un tipo identificador definido por la implementación que representa el hilo/subproceso.
Excepciones
Puede lanzar excepciones definidas por la implementación.
Ejemplo
Usa a native_handle para habilitar la programación en tiempo real de hilos/subprocesos de C++ en un sistema POSIX.
Ejecuta este código
#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 << "El hilo " << num << " se ejecuta con prioridad "
<< 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 << "Falla al llamar a setschedparam: " << std::strerror(errno) << '\n';
}
t1.join(); t2.join();
}
Salida:
El hilo 2 se ejecuta con prioridad 0
El hilo 1 se ejecuta con prioridad 20