如何在linux/unix中设置线程的优先级

int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void*), void *arg);
来创建线程,但是如何设置线程的优先级呢?
在讨论这个问题的时候,我们先要确定当前线程使用的调度策略,posix提供了
int pthread_attr_getschedpolicy(const pthread_attr_t *attr, int *policy);函数来获取所
使用的调度策略,它们是:SCHED_FIFO, SCHED_RR 和 SCHED_OTHER。

我们可以使用
int sched_get_priority_max(int policy);
int sched_get_priority_min(int policy);
来获取线程线程可是设置的最大和最小的优先级值,如果调用成功就返回最大和最小的优先级值,否则返回-1。
从我现在运行的linux系统中,我使用下列程序(程序见附录)获取了对应三种调度策略中的最大和最小优先级:
policy = SCHED_OTHER
Show current configuration of priority
max_priority = 0
min_priority = 0
Show SCHED_FIFO of priority
max_priority = 99
min_priority = 1
Show SCHED_RR of priority
max_priority = 99
min_priority = 1
Show priority of current thread
priority = 0
Set thread policy
Set SCHED_FIFO policy
policy = SCHED_FIFO
Set SCHED_RR policy
policy = SCHED_RR
Restore current policy
policy = SCHED_OTHER

我们可以看到
SCHED_OTHER 是不支持优先级使用的,而SCHED_FIFO和SCHED_RR支持优先级的使用,他们分别为1和99,数值越大优先级越高。从上面的结果我们可以看 出,如果程序控制线程的优先级,一般是用pthread_attr_getschedpolicy来获取系统使用的调度策略,如果是 SCHED_OTHER的话,表明当前策略不支持线程优先级的使用,否则可以。当然所设定的优先级范围必须在最大和最小值之间。我们可以通过 sched_get_priority_max和sched_get_priority_min来获取。

可能网友会问,是否我们可以通过 int pthread_attr_setschedpolicy(pthread_attr_t *attr, int policy);来设定自己所需的调度策略呢?我觉得是完全可以的(有些系统需要定义 _POSIX_THREAD_PRIORITY_SCHEDULING),只要系统实现了对应的调用策略。

说了半天,我们还没有说,在系统允许使用线程优先级别的时候,如何设置优先级别呢?
int pthread_attr_setschedparam(pthread_attr_t *attr, const struct sched_param *param);
int pthread_attr_getschedparam(const pthread_attr_t *attr,  struct sched_param *param);
上面两个函数分别用于设置线程的优先级,struct sched_param的定义如下
struct sched_param
{
int __sched_priority; //所要设定的线程优先级
};

例:创建优先级为10的线程
pthread_attr_t   attr;  
struct   sched_param   param;  
pthread_attr_init(&attr);  
pthread_attr_setschedpolicy(&attr,   SCHED_RR);  
param.sched_priority   =   10;  
pthread_attr_setschedparam(&attr,   &param);  
pthread_create(xxx   ,   &attr   ,   xxx   ,   xxx);  
pthread_attr_destroy(&attr);

附:使用的测试程序:

#include <iostream>
#include <pthread.h>
#include <sched.h>
#include <assert.h>

using namespace std;

static int get_thread_policy( pthread_attr_t &attr )
{
int policy;
int rs = pthread_attr_getschedpolicy( &attr, &policy );
assert( rs == 0 );
switch ( policy )
{
case SCHED_FIFO:
cout << "policy = SCHED_FIFO" << endl;
break;

case SCHED_RR:
cout << "policy = SCHED_RR" << endl;
break;

case SCHED_OTHER:
cout << "policy = SCHED_OTHER" << endl;
break;

default:
cout << "policy = UNKNOWN" << endl;
break;
}

return policy;
}

static void show_thread_priority( pthread_attr_t &attr, int policy )
{
int priority = sched_get_priority_max( policy );
assert( priority != -1 );
cout << "max_priority = " << priority << endl;

priority = sched_get_priority_min( policy );
assert( priority != -1 );
cout << "min_priority = " << priority << endl;
}

static int get_thread_priority( pthread_attr_t &attr )
{
struct sched_param param;

int rs = pthread_attr_getschedparam( &attr, &param );
assert( rs == 0 );
cout << "priority = " << param.__sched_priority << endl;

return param.__sched_priority;
}

static void set_thread_policy( pthread_attr_t &attr,  int policy )
{
int rs = pthread_attr_setschedpolicy( &attr, policy );
assert( rs == 0 );
get_thread_policy( attr );
}

int main( void )
{
pthread_attr_t attr;
struct sched_param sched;
int rs;

rs = pthread_attr_init( &attr );
assert( rs == 0 );

int policy = get_thread_policy( attr );

cout << "Show current configuration of priority" << endl;
show_thread_priority( attr, policy );

cout << "Show SCHED_FIFO of priority" << endl;
show_thread_priority( attr, SCHED_FIFO );

cout << "Show SCHED_RR of priority" << endl;
show_thread_priority( attr, SCHED_RR );

cout << "Show priority of current thread" << endl;
int priority = get_thread_priority( attr );

cout << "Set thread policy" << endl;
cout << "Set SCHED_FIFO policy" << endl;
set_thread_policy( attr, SCHED_FIFO );
cout << "Set SCHED_RR policy" << endl;
set_thread_policy( attr, SCHED_RR );
cout << "Restore current policy" << endl;
set_thread_policy( attr, policy );

rs = pthread_attr_destroy( &attr );
assert( rs == 0 );

return 0;
} 编译命令:#g++ pthread_priority3.c -o pthread_priority3 -lpthread

unix设置线程优先级-转相关推荐

  1. Android 中设置线程优先级的正确方式(2种方法)

    Android 中设置线程优先级的正确方式(2种方法) 在 Android 中,有两种常见的设置线程优先级的方式: 第一种,使用 Thread 类实例的 setPriority 方法,来设置线程优先级 ...

  2. ceSetThreadPriority设置线程优先级~!

    ceSetThreadPriority 一直採用SetThreadPriority,结果今天发帖询问线程时间问题,才突然顿悟...发现SetThreadPriority只设置248-255,也就是说就 ...

  3. android线程优先级大小,android 设置线程优先级 两种方式

    1) android.os.Process.setThreadPriority (int priority)或android.os.Process.setThreadPriority (int tid ...

  4. android 设置线程优先级

    1. android.os.Process.setThreadPriority (int priority)或  android.os.Process.setThreadPriority (int t ...

  5. Android线程优先级设置方法技巧

    对于Android平台上的线程优先级设置来说可以处理很多并发线程的阻塞问题, 比如很多无关紧要的线程会占用大量的CPU时间,虽然通过了MultiThread来解决慢速I/O但是合理分配优先级对于并发编 ...

  6. Linux-pthread如何设置线程的优先级

    设置线程优先级的函数: int pthread_setschedparam(pthread_t target_thread, int policy, const struct sched_param ...

  7. 【多线程】线程的引入,创建线程的方式,设置线程名字、获取名字,线程优先级priority,加入休眠的方法,,后台线程,礼让线程,Join,中断线程,某电影院,共有100张票线程流程图,3售票窗口,

    多线程 1.线程的引入 进程: 正在运行的程序,是系统进行资源分配和调用的独立单位.每一个进程都有它自己的内存空间和资源. 线程: 是进程的单个顺序控制流,或者说就是一个单独执行的路径 一个进程如果只 ...

  8. c语言怎么设置cpu优先级,线程优先级,设置,setPriority()方法

    package seday08.thread; /** * @author xingsir * 线程优先级 * 线程启动后纳入到线程调度,线程时刻处于被动获取CPU时间片而无法主动获取.我们可以通过调 ...

  9. Java 多线程:线程优先级

    1 优先级取值范围 Java 线程优先级使用 1 ~ 10 的整数表示: 最低优先级 1:Thread.MIN_PRIORITY 最高优先级 10:Thread.MAX_PRIORITY 普通优先级 ...

最新文章

  1. 1.8 centos7 的PATH、cp/mv/文档查看命令介绍
  2. 设置 VirtualBox 虚拟机访问局域网
  3. 互联网公司为啥都不用MySQL分区表?
  4. luogu P1058 立体图
  5. jquery查找父窗体id_Vue父组件获取子组件中的变量
  6. 「雕爷学编程」Arduino动手做(35)——模拟量声音传感器
  7. 【计算机网络笔记】因特网概述
  8. fig, ax = plt.subplots(figsize = (a, b))解析 与 plt.subplot()函数解析
  9. mysql 双1设置_2020-10-15:mysql的双1设置是什么?
  10. 计算机网络原理 谢希仁(第8版)第二章习题答案
  11. HP M1136无法打印的解决方法
  12. I-Deas TMG 培训资料 (7)
  13. 学习计算机组装与维护的意义,计算机组装与维护课程学习体会
  14. 【Python】断言(assert)
  15. 计算机 移动硬盘 图标删除,移动硬盘卸载图标丢失的解决办法 -电脑资料
  16. 网络编辑如何经营网络社区?
  17. Softing过程自动化解决方案——助力数字化工业
  18. openjudge 1.5.21 角谷猜想
  19. 上海出租车价格计算器
  20. Web开发未来会完全替代客户端开发吗?

热门文章

  1. 在linux中查找重复的文件夹,如何在Linux上找出并删除重复的文件:FSlint
  2. asyncio 文件io高并发_用 asyncio 封装文件读写
  3. linkhashmap原理_LinkedHashMap 用法
  4. 阿发你好java_191122_01 纯前端JS实现的文字验证码
  5. CrazyWing:Python自动化运维开发实战 五、Python运算符与表达式
  6. [转]Newtonsoft.Json高级用法
  7. springboot 常用插件
  8. 【Oracle】-【LRU和DBWR】-LRU算法与DBWR中的应用
  9. WIN7下VS2005 VS2008 SQLSERVER2005安装顺序
  10. 【干货】无人机如何进行倾斜摄影的航线规划