转: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
                   
3.    线程的作用域:
                               
            函数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   (系统级竞争资源)。
                   
4.    线程堆栈的大小
           
            函数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。           
       
5.    线程堆栈的地址           
           
            #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

6.    警戒缓冲区
           
            函数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。

  关于线程的绑定,牵涉到另外一个概念:轻进程(LWP:Light Weight Process)。轻进程可以理解为内核线程,它位于用户层和系统层之间。系统对线程资源的分配、对线程的控制是通过轻进程来实现的,一个轻进程可以控制一个或多个线程。默认状况下,启动多少轻进程、哪些轻进程来控制哪些线程是由系统来控制的,这种状况即称为非绑定的。绑定状况下,则顾名思义,即某个线程固定的"绑"在一个轻进程之上。被绑定的线程具有较高的响应速度,这是因为CPU时间片的调度是面向轻进程的,绑定的线程可以保证在需要的时候它总有一个轻进程可用。通过设置被绑定的轻进程的优先级和调度级可以使得绑定的线程满足诸如实时反应之类的要求。设置线程绑定状态的函数为pthread_attr_setscope,它有两个参数,第一个是指向属性结构的指针,第二个是绑定类型,它有两个取值:PTHREAD_SCOPE_SYSTEM(绑定的)和PTHREAD_SCOPE_PROCESS(非绑定的)。

#include <stdlib.h>   
#include <stdio.h>   
#include <errno.h>   
#include <pthread.h>   
static void pthread_func_1 (void);   
static void pthread_func_2 (void);   
int main (int argc, char** argv)   
{   
  pthread_t pt_1 = 0;   
  pthread_t pt_2 = 0;   
  pthread_attr_t atrr = {0};   
  int ret = 0;   

/*初始化属性线程属性*/

  pthread_attr_init (&attr);   
  pthread_attr_setscope (&attr, PTHREAD_SCOPE_SYSTEM);   
  pthread_attr_setdetachstate (&attr, PTHREAD_CREATE_DETACHED);   
  ret = pthread_create (&pt_1, &attr, pthread_func_1, NULL);   
  if (ret != 0)   
  {   
      perror ("pthread_1_create");   
  }   
  ret = pthread_create (&pt_2, NULL, pthread_func_2, NULL);   
  if (ret != 0)   
  {   
      perror ("pthread_2_create");   
  }   
  pthread_join (pt_2, NULL);   
  return 0;   
}   
 
static void pthread_func_1 (void)   
{   
  int i = 0; 
  for (; i < 6; i++)   
  {    
    printf ("This is pthread_1.\n");    
    if (i == 2)   
    {   
        pthread_exit (0);   
    }   
  }   
  return;   
}  
static void pthread_func_2 (void)    
{   
  int i = 0;  
  for (; i < 3; i ++)   
  {   
      printf ("This is pthread_2.\n");   
  }   
  return;   
}  

//-----------------------------------------------------------------------------------------------------------

//线程的调度参考网址: //http://blog.csdn.net/maray/article/details/2900689

线程属性pthread_attr_t的更多相关文章

  1. 线程属性 pthread_attr_t

    参考资料: https://blog.csdn.net/hudashi/article/details/7709413 Posix线程中的线程属性pthread_attr_t主要包括scope属性.d ...

  2. 线程属性pthread_attr_t简介

    本文编辑整理自: http://hi.baidu.com/7828058/blog/item/256e16decd1a385e94ee3784.html http://www.ibm.com/deve ...

  3. LInux多线程编程----线程属性pthread_attr_t

    1.每个POSIX线程有一个相连的属性对象来表示属性.线程属性对象的类型是pthread_attr_t,pthread_attr_t 在文件/usr/include/bits/pthreadtypes ...

  4. Linux 线程属性函数总结

    1.初始化一个线程对象的属性 int pthread_attr_init(pthread_attr_t *attr); 返回值:若是成功返回0,否则返回错误的编号 形 参: attr 指向一个线程属性 ...

  5. UNIX环境高级编程——线程属性

    pthread_attr_t 的缺省属性值 属性 值 结果 scope PTHREAD_SCOPE_PROCESS 新线程与进程中的其他线程发生竞争. detachstate PTHREAD_CREA ...

  6. 三十八、Linux 线程——线程属性初始化、销毁、设置和获得分离属性

    38.1 线程属性初始化和销毁 #include <pthread.h> int pthread_attr_init(pthread_attr_t *attr); int pthread_ ...

  7. UNIX环境编程学习笔记(27)——多线程编程(二):控制线程属性

    lienhua342014-11-09 1 线程属性概括 POSIX 线程的主要属性包括 scope 属性.detach 属性.堆栈地址.堆栈大小.优先级.在头文件 pthread.h 中定义了结构体 ...

  8. Linux的POSIX线程属性

    创建POSIX线程的函数为 int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routin ...

  9. pthread_attr_t 线程属性(二)

    一.函数: 1.线程属性的初始化与销毁:#include <pthread.h>int pthread_attr_init(pthread_attr_t *attr);int pthrea ...

随机推荐

  1. [PCL]4 PCL中图像匹配的几个类图

    IterativeClosestPoint () { reg_name_ = "IterativeClosestPoint"; ransac_iterations_ = ; tra ...

  2. shellinabox安装

    Shell In A Box(发音是shellinabox)是一款基于Web的终端模仿器,由Markus Gutschke开辟而成.它有内置的Web办事器,在指定的端口上作为一个基于Web的SSH客户 ...

  3. Java基础之在窗口中绘图——绘制直线和矩形(Sketcher 2 drawing lines and rectangles)

    控制台程序. import javax.swing.JComponent; import java.util.*; import java.awt.*; import java.awt.geom.*; ...

  4. log4cxx安装和使用

    log4cxx是Java社区著名的log4j的c++移植版,用于为C++程序提供日志功能,以便开发者对目标程序进行调试和审计,log4cxx是apache软件基金会的开源项目,基于APR实现跨平台支持 ...

  5. Leetcode: Insert Delete GetRandom O(1) - Duplicates allowed

    Design a data structure that supports all following operations in average O(1) time. Note: Duplicate ...

  6. C++Builder组件

    1.TOpenDialog: Title属性:用于获取或设置对话框标题,如果么偶有给该属性赋值,则系统将使用默认值标题:“打开” .InitialDir属性:用于获取或设置文件对话框显示的初始目录.如 ...

  7. AngularJs Test demo &front end MVVM implementation conjecture and argue.

    <!DOCTYPE html> <html> <head> <title></title> <meta charset="u ...

  8. extjs 常见的小问题

    今天,小白就来总结下extjs的使用的时候的各种小问题或者说是小技巧.希望能够给各位刚接触extjs的朋友一点帮助. 1.当存在store的各种组件的store的autoload属性为false的时候 ...

  9. javascript浏览器对象

    window对象 1.window对象 window对象是BOM的核心,window对象指当前的浏览器窗口 所有JS全局对象.函数以及变量均自动成为window对象的成员 全局变量是window对象的 ...

  10. 全局函数VS成员函数

    #include <iostream> using namespace std; class Test { public: Test(int a, int b) { this->a ...