Linux线程属性及优先级设置

【原文引自】http://hikesoso2010.spaces.eepw.com.cn/articles/article/item/86413#

线程的属性由pthread_attr_t结构类型表示。

  在使用pthread_attr_t之前,需要调用pthread_attr_init对其初始化。pthread_attr_init为pthread_attr_t结构里面的各个属性设置默认值。程序可以修改这些值,定制线程的各个属性。在使用完pthread_attr_t后,需要调用pthread_attr_destroy,完成一些清理工作。

  int pthread_attr_init ( pthread_attr_t *attr );

  int pthread_attr_destroy ( pthread_attr_t *attr );

  无需了解pthread_attr_t的具体结构,POSIX.1指定了一系列方法获取和设置pthread_attr_t结构里面的各个属性。

  (1)分离状态(detached state):若线程终止时,线程处于分离状态,系统不保留线程终止的状态。当不需要线程的终止状态时,可以分离线程(调用pthread_detach 函数)。若在线程创建的时候,就已经知道以后不需要使用线程的终止状态时,可以在线程创建属性里面指定该状态,那么线程一开始就处于分离状态。通过下面两个函数,设置和获取线程的分离属性。

  int pthread_attr_getdetachstate ( const pthread_attr_t *attr, int *state );

  int pthread_attr_setdetachstate ( pthread_attr_t *attr, int state );

  该属性的可选值有:PTHREAD_CREATE_DETACHED、PTHREAD_CREATE_JOINABLE。

  (2)栈地址(stack address):POSIX.1定义了两个常量_POSIX_THREAD_ATTR_STACKADDR 和_POSIX_THREAD_ATTR_STACKSIZE检测系统是否支持栈属性。当然也可以给sysconf函数传递_SC_THREAD_ATTR_STACKADDR或 _SC_THREAD_ATTR_STACKSIZE来进行检测。当进程栈地址空间不够用时,指定新建线程使用由malloc分配的空间作为自己的栈空间。通过pthread_attr_setstackaddr和pthread_attr_getstackaddr两个函数分别设置和获取线程的栈地址。传给pthread_attr_setstackaddr函数的地址是缓冲区的低地址(不一定是栈的开始地址,栈可能从高地址往低地址增长)。

  int pthread_attr_getstackaddr ( const pthread_attr_t *attr, void **addr );

  int pthread_attr_setstackaddr ( pthread_attr_t *attr, void *addr );

  (3)栈大小(stack size):当系统中有很多线程时,可能需要减小每个线程栈的默认大小,防止进程的地址空间不够用;当线程调用的函数会分配很大的局部变量或者函数调用层次很深时,可能需要增大线程栈的默认大小。函数pthread_attr_getstacksize和 pthread_attr_setstacksize被提供。

  int pthread_attr_getstacksize ( const pthread_attr_t *attr, size_t *size );

  int pthread_attr_setstacksize ( pthread_attr_t *attr, size_t size );

  函数pthread_attr_getstack和pthread_attr_setstack函数可以同时操作栈地址和栈大小两个属性:

  int pthread_attr_getstack ( const pthread_attr_t *attr, void **stackaddr, size_t *size );

  int pthread_attr_setstack ( pthread_attr_t *attr, void *stackaddr, size_t size );

  (4)栈保护区大小(stack guard size):在线程栈顶留出一段空间,防止栈溢出。当栈指针进入这段保护区时,系统会发出错误,通常是发送信号给线程。该属性默认值是PAGESIZE大小,该属性被设置时,系统会自动将该属性大小补齐为页大小的整数倍。当改变栈地址属性时,栈保护区大小通常清零。

  int pthread_attr_getguardsize ( const pthread_attr_t *attr, size_t *guardsize );

  int pthread_attr_setguardsize ( pthread_attr_t *attr, size_t guardsize );

  (5)线程优先级(priority):新线程的优先级为 0。

  int pthread_attr_getschedparam(const pthread_attr_t *restrict attr, struct sched_param *restrict param);

  int pthread_attr_setschedparam(pthread_attr_t *restrict attr, const struct sched_param *restrict param);

  (6)继承父进程优先级(inheritsched):新线程不继承父线程调度优先级(PTHREAD_EXPLICIT_SCHED)

  (7)调度策略(schedpolicy):新线程使用 SCHED_OTHER 调度策略。线程一旦开始运行,直到被抢占或者直到线程阻塞或停止为止。

  int pthread_attr_setschedpolicy(pthread_attr_t* attr, int policy)

  int pthread_attr_setschedparam (pthread_attr_t* attr, struct sched_param* param);

  (8)争用范围(scope)建立线程的争用范围(PTHREAD_SCOPE_SYSTEM 或 PTHREAD_SCOPE_PROCESS)。使用 PTHREAD_SCOPE_SYSTEM 时,此线程将与系统中的所有线程进行竞争。使用 PTHREAD_SCOPE_PROCESS 时,此线程将与进程中的其他线程进行竞争。这个又叫绑定状态,PTHREAD_SCOPE_SYSTEM(绑定的)和PTHREAD_SCOPE_PROCESS(非绑定的)。具有不同范围状态的线程可以在同一个系统甚至同一个进程中共存。进程范围只允许这种线程与同一进程中的其他线程争用资源,而系统范围则允许此类线程与系统内的其他所有线程争用资源。对于Solaris系统,实际上,从 Solaris 9 发行版开始,系统就不再区分这两个范围。

  int pthread_attr_getscope(const pthread_attr_t *restrict attr, int *restrict contentionscope);

  int pthread_attr_setscope(pthread_attr_t *attr, int contentionscope);

  (9)线程并行级别(concurrency)应用程序使用 pthread_setconcurrency() 通知系统其所需的并发级别。

  int pthread_getconcurrency(void);

  int pthread_setconcurrency(int new_level);

  POSIX标准指定了三种调度策略:先入先出策略 (SCHED_FIFO)、循环策略 (SCHED_RR) 和自定义策略 (SCHED_OTHER)。SCHED_FIFO 是基于队列的调度程序,对于每个优先级都会使用不同的队列。SCHED_RR 与 FIFO 相似,不同的是前者的每个线程都有一个执行时间配额。

  SCHED_FIFO 和 SCHED_RR 是对 POSIX Realtime 的扩展。SCHED_OTHER 是缺省的调度策略。

  POSIX标准指定了三种调度策略:先入先出策略 (SCHED_FIFO)、循环策略 (SCHED_RR) 和自定义策略 (SCHED_OTHER)。SCHED_FIFO 是基于队列的调度程序,对于每个优先级都会使用不同的队列。SCHED_RR 与 FIFO 相似,不同的是前者的每个线程都有一个执行时间配额。

  SCHED_FIFO

  如果调用进程具有有效的用户 ID 0,则争用范围为系统 (PTHREAD_SCOPE_SYSTEM) 的先入先出线程属于实时 (RT) 调度类。如果这些线程未被优先级更高的线程抢占,则会继续处理该线程,直到该线程放弃或阻塞为止。对于具有进程争用范围 (PTHREAD_SCOPE_PROCESS)) 的线程或其调用进程没有有效用户 ID 0 的线程,请使用 SCHED_FIFO。SCHED_FIFO 基于 TS 调度类。

  SCHED_RR

  如果调用进程具有有效的用户 ID 0,则争用范围为系统 (PTHREAD_SCOPE_SYSTEM)) 的循环线程属于实时 (RT) 调度类。如果这些线程未被优先级更高的线程抢占,并且这些线程没有放弃或阻塞,则在系统确定的时间段内将一直执行这些线程。对于具有进程争用范围 (PTHREAD_SCOPE_PROCESS) 的线程,请使用 SCHED_RR(基于 TS 调度类)。此外,这些线程的调用进程没有有效的用户 ID 0。

  例:创建优先级为50的线程。

  pthread_attr_t attr;

  struct sched_param param;

  pthread_attr_init(&attr);

  pthread_attr_setschedpolicy(&attr, SCHED_RR);

  param.sched_priority = 50;

  pthread_attr_setschedparam(&attr, ¶m);

  pthread_create(&threadid, &attr, &threadfunc, NULL);

  pthread_attr_destroy(&attr);

Linux线程属性及优先级设置相关推荐

  1. linux设置进程优先级,Linux线程属性及优先级设置

    POSIX.1线程属性及优先级设置 By zieckey All Right Reserved 线程的属性由pthread_attr_t结构类型表示. 在使用pthread_attr_t之前,需要调用 ...

  2. Linux线程属性总结 http://blog.csdn.net/zsf8701/article/details/7842392

    Linux线程属性总结 分类: Linux 2012-08-08 11:05  3657人阅读  评论(2)  收藏  举报 linux thread solaris concurrency syst ...

  3. java线程——中断线程+线程状态+线程属性(优先级)

    [0]README 0.1) 本文描述转自 core java volume 1, 源代码为原创,旨在理解 java线程--中断线程+线程状态+线程属性(优先级) 的相关知识: [1]中断线程 1.1 ...

  4. Linux线程属性总结

    http://blog.csdn.net/zsf8701/article/details/7843837 线程属性标识符:pthread_attr_t 包含在 pthread.h 头文件中. [c]  ...

  5. Linux 线程属性的使用

    线程属性 线程具有属性,用pthread_attr_t表示,在对该结构进行处理之前必须进行初始化,在使用后需要对其去除初始化.我们用pthread_attr_init函数对其初始化,用pthread_ ...

  6. linux内核线程优先级设置,Linux c 线程属性,线程优先级的修改

    Linux c 线程属性,线程优先级的修改 发布时间:2018-07-19 10:24, 浏览次数:1290 , 标签: Linux 线程属性的设置,网上找的文章总感觉不够全面,还是结合man手册查看 ...

  7. 【C++ 语言】线程 ( 线程创建方法 | 线程标识符 | 线程属性 | 线程属性初始化 | 线程属性销毁 | 分离线程 | 线程调度策略 | 线程优先级 | 线程等待 )

    文章目录 I 线程创建方法 II 线程执行函数 III 线程标识符 IV 线程属性 V 线程属性 1 ( 分离线程 | 非分离线程 ) VI 线程属性 2 ( 线程调度策略 ) VII 线程属性 3 ...

  8. Linux线程基本知识

    1.线程: 由于进程的地址空间是私有的,因此在进程间上下文切换时,系统开销比较大, 为了提高系统的性能,许多操作系统规范里引入了轻量级进程的概念,也被称为线程,在同一个进程中创建的线程共享该进程的地址 ...

  9. linux多线程学习(三)——线程属性设置

    在上一篇文章中,介绍了线程的创建和退出,以及相关函数的使用.其中pthread_create函数的第二个参数,是关于线程属性的设置,这也是今天所有讲述的.这些属性主要包括邦定属性.分离属性.堆栈地址. ...

最新文章

  1. Linux中如何恢复被误删的数据文件
  2. C# 消息处理学习总结
  3. #地形剖面图_高中地理——每日讲1题(地形剖面图)
  4. pythonjpg_使用python判断jpeg图片的完整性实例
  5. JS基础--函数与BOM、DOM操作、JS中的事件以及内置对象
  6. 今天微软关闭Silverlight官网,Sivlerlight真得要死了吗?
  7. python中bar是什么意思_Python中下划线的变量是什么个意思
  8. 什么是复制和交换习语?
  9. 实验2-1-3 计算物体自由下落的距离 (5 分)
  10. android创建桌面快捷键shortcut
  11. 74LS138译码器的IP核设计
  12. php输入框形式,php输入框
  13. 【数据库】数据库入门(五): 实体关系模型 (Entity-Relationship Model)
  14. PrimeNG之DataTable
  15. 在Windows 8/WP/Silverlight/WPF下创建五角星
  16. ARM开发板使用GDB调试程序
  17. 融资融券黑马选股分析系统主力意图大资金流出流入短线涨停板股票炒股软件
  18. 关于Unity中的NGUI优化,你可能遇到这些问题
  19. 微信小程序web-view的使用教程
  20. Phonics 自然拼读法 ai ay ee ea ey ie igh oa ow ui ue 元音字母组合 Teacher:Lamb

热门文章

  1. vega56刷64_Vega56刷入BIOS跑分直逼旗舰Vega64
  2. 使用腾讯OCR,图片转表格
  3. pandas seaborn绘制箱型图,探索时间序列数据季节性
  4. jupyter显示dataframe完整的行与列
  5. mysql.sys_MySQL sys Schema
  6. php 跳转到另外一个php,PHP: 其他变更 - Manual
  7. git pull 分支问题
  8. kafka跨集群同步方案
  9. Facebook 内部高效工作PPT
  10. SEO技巧之网站优化的具体细节