Espacios de nombres
Variantes
Acciones

std::jthread::native_handle

De cppreference.com
< cpp‎ | thread‎ | jthread
 
 
Biblioteca de apoyo de concurrencia
Hilos
(C++11)
(C++20)
Espacio de nombres this_thread
(C++11)
(C++11)
(C++11)
Cancelación cooperativa
Exclusión mutua
(C++11)
Gestión genérica de bloqueo
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Variables de condición
(C++11)
Semáforos
Pestillos y barreras
(C++20)
(C++20)
Futuros
(C++11)
(C++11)
(C++11)
(C++11)
Recuperación segura
(C++26)
Punteros de riesgo
Tipos atómicos
(C++11)
(C++20)
Inicialización de tipos atómicos
(C++11)(en desuso en C++20)
(C++11)(en desuso en C++20)
Orden de memoria
Funciones independientes para operaciones atómicas
Funciones independientes para indicadores atómicos
 
 
[[nodiscard]] native_handle_type native_handle();
(desde C++20)
(opcional)

Devuelve el identificador de hilo/subproceso subyacente definido por la implementación.

Contenido

[editar] Parámetros

(Ninguno)

[editar] Valor de retorno

Un tipo identificador definido por la implementación que representa el hilo/subproceso.

[editar] Excepciones

Puede lanzar excepciones definidas por la implementación.

[editar] Ejemplo

Usa a native_handle para habilitar la programación en tiempo real de hilos/subprocesos de C++ en un sistema POSIX.

#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::jthread 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';
    }
 
 
}

Salida:

El hilo 2 se ejecuta con prioridad 0
El hilo 1 se ejecuta con prioridad 20