Linux线程pthread_attr_t 线程属性(转)

ATTENTION:附加代码链接:
http://blog.sina.com.cn/s/blog_6dc9e4cf0100xcvk.html

  1. 线程属性:
    使用pthread_attr_t类型表示,我们需要对此结构体进行初始化,
    初始化后使用,使用后还要进行去除初始化!
    pthread_attr_init:初始化
    pthread_attr_destory:去除初始化

          #include <pthread.h>
          int pthread_attr_init(pthread_attr_t *attr);
          int pthread_attr_destroy(pthread_attr_t *attr);   
          若成功返回0,若失败返回-1。
         
          pthread_attr_init之后,pthread_t结构所包含的内容就是操作系统实现
          支持的线程所有属性的默认值。
         
          如果pthread_attr_init实现时为属性对象分配了动态内存空间,
          pthread_attr_destroy还会用无效的值初始化属性对象,因此如果经
          pthread_attr_destroy去除初始化之后的pthread_attr_t结构被
          pthread_create函数调用,将会导致其返回错误。
         
          线程属性结构如下:
    
          typedef struct
          {
                 int                           detachstate;     线程的分离状态
                 int                          schedpolicy;   线程调度策略
                 struct sched_param      schedparam;   线程的调度参数
                 int                          inheritsched;    线程的继承性
                 int                          scope;          线程的作用域
                 size_t                      guardsize; 线程栈末尾的警戒缓冲区大小
                 int                          stackaddr_set;
                 void *                     stackaddr;      线程栈的位置
                 size_t                      stacksize;       线程栈的大小
          }pthread_attr_t;
         
          下面主要讨论此结构体!!!
    
  2. 分离状态:
    线程的分离状态决定一个线程以什么样的方式来终止自己。

      我们已经在前面已经知道,在默认情况下线程是非分离状态的,这种情况   
      下,原有的线程等待创建的线程结束。只有当pthread_join() 函数返回       
      时,创建的线程才算终止,才能释放自己占用的系统资源。   
     
      分离线程没有被其他的线程所等待,自己运行结束了,线程也就终止了,
      马上释放系统资源。
     
      通俗的说也就是:我们知道一般我们要等待(pthread_join)一个线程的结束,
      主要是想知道它的结束状态,否则等待一般是没有什么意义的!但是if有一
      些线程的终止态我们压根就不想知道,那么就可以使用“分离”属性,那么我
      们就无须等待管理,只要线程自己结束了,自己释放src就可以咯!这样更
      方便!
     
      #include <pthread.h>
      int pthread_attr_getdetachstate(const pthread_attr_t * attr, int * detachstate);
      int pthread_attr_setdetachstate(pthread_attr_t * attr, int detachstate);
      参数:attr:线程属性变量
              detachstate:分离状态属性   
      若成功返回0,若失败返回-1。
     
      设置的时候可以有两种选择:
      <1>.detachstate参数为:PTHREAD_CREATE_DETACHED     分离状态启动
      <2>.detachstate参数为:PTHREAD_CREATE_JOINABLE    正常启动线程
    
  3. 线程的继承性:

      函数pthread_attr_setinheritsched和pthread_attr_getinheritsched分别用来设
      置和得到线程的继承性!
     
      #include <pthread.h>
      int pthread_attr_getinheritsched(const pthread_attr_t *attr,int *inheritsched);
      int pthread_attr_setinheritsched(pthread_attr_t *attr,int inheritsched);
      参数:
      attr                线程属性变量
      inheritsched     线程的继承性
      若成功返回0,若失败返回-1。
     
      请注意:
      继承性决定调度的参数是从创建的进程中继承还是使用在 
      schedpolicy和schedparam属性中显式设置的调度信息。           
                             
      线程没有默认的继承值设置,所以如果关心线程的调度策略和参数,
      只能手动设置!
     
      可设置参数:
      PTHREAD_INHERIT_SCHED: 新的线程继承创建线程的策略和参数!
      PTHREAD_EXPLICIT_SCHED:新的线程继承策略和参数来自于
                                          schedpolicy和schedparam属性中显式
                                          设置的调度信息!
    

: 下面补充线程调度策略和调度参数:
<1>.调度策略:

                函数pthread_attr_setschedpolicy和pthread_attr_getschedpolicy分别用
                来设置和得到线程的调度策略。
               
                int pthread_attr_getschedpolicy(const pthread_attr_t *, int * policy)
                int pthread_attr_setschedpolicy(pthread_attr_*, int policy)
                参数:
                        attr            线程属性变量
                        policy        调度策略   
                若成功返回0,若失败返回-1。
               
                所谓调度策略也就是我们之前在OS中所学过的那些调度算法:
                SCHED_FIFO    :先进先出
                SCHED_RR       :轮转法
                SCHED_OTHER    :其他方法
               
                SCHED_OTHER是不支持优先级使用的,而SCHED_FIFO和SCHED_RR
                支持优先级的使用,他们分别为1和99,数值越大优先级越高.
               
                注意:
                        > 此处的SCHED_FIFO是允许被高优先级抢占的!
                        > 也就是有高优先级的必须先运行
                        > SCHED_RR是设置一个时间片
                        > 当有SCHED_FIFO或SCHED_RR策赂的线程在一个条件变量
                        上等持或等持加锁同一个互斥量时,它们将以优先级顺序被唤
                        醒。即,如果一个低优先级的SCHED_FIFO线程和一个高优先
                        织的SCHED_FIFO线程都在等待锁相同的互斥且,则当互斥量
                        被解锁时,高优先级线程将总是被首先解除阻塞。
                       
        <2>.调度参数:
               
                函数pthread_attr_getschedparam 和pthread_attr_setschedparam分别
                用来设置和得到线程的调度参数。
               
                   

                int pthread_attr_getschedparam(const pthread_attr_t *,struct
                sched_param *);
                int pthread_attr_setschedparam(pthread_attr_t *,const struct
                sched_param *);
                参数:
                        attr            线程变量属性
                        param        sched_parm 结构体
                若成功返回0,若失败返回-1。
               
                /usr/include /bits/sched.h
                struct sched_param
                {
                       int sched_priority;    //!> 参数的本质就是优先级
                };
                注意:大的权值对应高的优先级!
                系统支持的最大和最小的优先级值可以用函数:
                sched_get_priority_max和sched_get_priority_min得到!
               
                #include <pthread.h>
                int sched_get_priority_max( int policy );
                int sched_get_priority_min( int policy );
                参数:max_:    系统支持的优先级的最小值
                        min_ :    系统支持的优先级的最大值
               
                使用:max_ = sched_get_priority_max( policy );
                        min_ = sched_get_priority_min( policy );
                        注意参数是policy调用策略,也就是说对于不同的策略的值是不
                        一样的!
           
                附录:来自
                http://www.yuanma.org/data/2006/0823/article_1392.htm
                policy = SCHED_OTHER
                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
  1. 线程的作用域:

      函数pthread_attr_setscope和pthread_attr_getscope分别
      用来设置和得到线程的作用域。       
      #include <pthread.h>   
      int    pthread_attr_getscope( const pthread_attr_t * attr, int * scope );
      int pthread_attr_setscope( pthread_attr_t*, int scope );
      参数:
              attr               线程属性变量
              scope         线程的作用域       
      若成功返回0,若失败返回-1。
     
      作用域控制线程是否在进程内或在系统级上竞争资源,可能的值是
      PTHREAD_SCOPE_PROCESS(进程内竞争资源)
      PTHREAD_SCOPE_SYSTEM   (系统级竞争资源)。
    
  2. 线程堆栈的大小

      函数pthread_attr_setstackaddr和pthread_attr_getstackaddr分别用来设置和得
      到线程堆栈的位置。
     
      int pthread_attr_getstacksize(const pthread_attr_t *,size_t * stacksize);
      int pthread_attr_setstacksize(pthread_attr_t *attr ,size_t *stacksize);
      参数:attr                线程属性变量
              stacksize        堆栈大小
      若成功返回0,若失败返回-1。           
    
  3. 线程堆栈的地址

      #include <pthread.h>
      int pthread_attr_getstackaddr(const pthread_attr_t *attr,void **stackaddf);
      int pthread_attr_setstackaddr(pthread_attr_t *attr,void *stackaddr);
      参数:attr               线程属性变量
              stackaddr     堆栈地址           
      若成功返回0,若失败返回-1。
     
      注意:pthread_attr_getstackaddr已经过期,现在使用的是:pthread_attr_getstack
    
  4. 警戒缓冲区

      函数pthread_attr_getguardsize和pthread_attr_setguardsize分别用来设置和得
      到线程栈末尾的警戒缓冲区大小。
    
      #include <pthread.h>                   
      int pthread_attr_getguardsize(const pthread_attr_t *restrict attr,size_t *restrict
      guardsize);
      int pthread_attr_setguardsize(pthread_attr_t *attr ,size_t *guardsize);
      若成功返回0,若失败返回-1。
     
      值得注意:
                  线程属性guardsize控制着线程栈末尾之后以避免栈溢出的扩展内存
                  大小。这个属性默认设置为PAGESIZE个字节。可以把guardsize线
                  程属性设为0,从而不允许属性的这种特征行为发生:在这种情况
                  下不会提供警戒缓存区。同样地,如果对线程属性stackaddr作了
                  修改,系统就会认为我们会自己管理栈,并使警戒栈缓冲区机制无
                  效,等同于把guardsize线程属性设为0。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,490评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,581评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,830评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,957评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,974评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,754评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,464评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,847评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,995评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,137评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,819评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,482评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,023评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,149评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,409评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,086评论 2 355

推荐阅读更多精彩内容