Esa es la plantilla básica de cómo lo haría, pero después de buscar no encontré ejemplos de código, así que creo que el veredicto es si es mejor o no.
El problema es que impulso :: hilo no tiene un constructor que permite a los atributos para ser aprobada en la creación del hilo en pthead lo que tiene que hacer cambios después de que el hilo se inicia. La única otra manera que conozco para solucionarlo es a través de la herencia de proceso/programación de hilos. A menos que se indique lo contrario, los hilos nuevos heredarán el cronograma/prioridad de su creador para que pueda cambiar el hilo actual antes de crear los hilos de trabajo y luego cambiarlos si lo desea. Parece incómodo, pero es una alternativa.
Aquí hay un truco de un ejemplo que con suerte demuestra ambos. Es posible que deba cambiar la política y la prioridad según corresponda y ejecutar como root.
Tenga cuidado con la forma de establecer la prioridad. Se aplican varias restricciones.
#include <iostream>
#include <boost/thread/thread.hpp>
#include <unistd.h>
#include <sched.h>
#include <cstdio>
void* threadfunc()
{
sleep(5);
}
void displayAndChange(boost::thread& daThread)
{
int retcode;
int policy;
pthread_t threadID = (pthread_t) daThread.native_handle();
struct sched_param param;
if ((retcode = pthread_getschedparam(threadID, &policy, ¶m)) != 0)
{
errno = retcode;
perror("pthread_getschedparam");
exit(EXIT_FAILURE);
}
std::cout << "INHERITED: ";
std::cout << "policy=" << ((policy == SCHED_FIFO) ? "SCHED_FIFO" :
(policy == SCHED_RR) ? "SCHED_RR" :
(policy == SCHED_OTHER) ? "SCHED_OTHER" :
"???")
<< ", priority=" << param.sched_priority << std::endl;
policy = SCHED_FIFO;
param.sched_priority = 4;
if ((retcode = pthread_setschedparam(threadID, policy, ¶m)) != 0)
{
errno = retcode;
perror("pthread_setschedparam");
exit(EXIT_FAILURE);
}
std::cout << " CHANGED: ";
std::cout << "policy=" << ((policy == SCHED_FIFO) ? "SCHED_FIFO" :
(policy == SCHED_RR) ? "SCHED_RR" :
(policy == SCHED_OTHER) ? "SCHED_OTHER" :
"???")
<< ", priority=" << param.sched_priority << std::endl;
}
int main(int argc, char* argv[])
{
int policy, res;
struct sched_param param;
if ((policy = sched_getscheduler(getpid())) == -1)
{
perror("sched_getscheduler");
exit(EXIT_FAILURE);
}
if ((res = sched_getparam(getpid(), ¶m)) == -1)
{
perror("sched_getparam");
exit(EXIT_FAILURE);
}
std::cout << " ORIGINAL: ";
std::cout << "policy=" << ((policy == SCHED_FIFO) ? "SCHED_FIFO" :
(policy == SCHED_RR) ? "SCHED_RR" :
(policy == SCHED_OTHER) ? "SCHED_OTHER" :
"???")
<< ", priority=" << param.sched_priority << std::endl;
policy = SCHED_RR;
param.sched_priority = 2;
if ((res = sched_setscheduler(getpid(), policy, ¶m)) == -1)
{
perror("sched_setscheduler");
exit(EXIT_FAILURE);
}
boost::thread t1(&threadfunc);
displayAndChange(t1);
t1.join();
return 0;
}
Arafangion: ¿Tiene algo que respaldar? La página del manual de linux para pthread_attr_setschedparam dice que funciona. Además, mi experiencia personal es que funciona exactamente como está documentado. –