侧边栏壁纸
博主头像
noerror

虚灵不寐,众理具而万事出。

  • 累计撰写 239 篇文章
  • 累计创建 9 个标签
  • 累计收到 2 条评论
标签搜索

目 录CONTENT

文章目录

pthread_getattr_default_np函数用法详解

noerror
2022-10-04 / 0 评论 / 0 点赞 / 122 阅读 / 775 字 / 正在检测是否收录...

pthread_getattr_default_np函数用法详解

pthread_getattr_default_np函数简介

  • 头文件包含
#include <pthread.h>
  • 函数定义
int pthread_getattr_default_np(pthread_attr_t * attr );
int pthread_setattr_default_np(pthread_attr_t * attr );
  • 编译链接选项
-pthread

pthread_getattr_default_np函数常见使用错误

  • 链接错误
    undefined reference to `pthread_getattr_default_np'
    解决办法:添加链接选项
-pthread
  • 编译错误
    warning: implicit declaration of function ‘pthread_getattr_default_np’ [-Wimplicit-function-declaration]
    解决办法:包含头文件
#include <pthread.h>

pthread_getattr_default_np函数详细描述

pthread_setattr_default_np ()函数设置用于创建新线程的默认属性(EM,即当使用第二个参数null调用pthread_create (3)时使用的属性。默认属性是使用*attr 中提供的属性设置的,该属性是以前初始化的线程属性对象。请注意以下关于提供的属性对象的详细信息:

  • 对象中的属性设置必须有效。
  • 不能在对象中设置"stack address"属性。
  • 将"stack size"属性设置为零意味着保持默认堆栈大小不变。

pthread_getattr_default_np ()函数初始化attr引用的thread attributes对象,以便它包含用于创建线程的默认属性。

pthread_getattr_default_np函数错误码

  • EINVAL ( pthread_setattr_default_np ()) attr中的一个属性设置无效,或者在attr 中设置了堆栈地址属性
  • ENOMEM ( pthread_setattr_default_np ())内存不足。

pthread_getattr_default_np函数使用举例

下面的程序使用pthread_getattr_default_np ()来获取默认的线程创建属性,然后从返回的thread attributes对象中显示各种设置。在运行程序时,我们看到以下输出:

$ \fB./a.out\fP
Stack size:          8388608
Guard size:          4096
Scheduling policy:   SCHED_OTHER
Scheduling priority: 0
Detach state:        JOINABLE
Inherit scheduler:   INHERIT

Program source&

#define _GNU_SOURCE
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>

#define errExitEN(en, msg) \e
                       do { errno = en; perror(msg); \e
                            exit(EXIT_FAILURE); } while (0)

static void
display_pthread_attr(pthread_attr_t *attr)
{
   int s;
   size_t stacksize;
   size_t guardsize;
   int policy;
   struct sched_param schedparam;
   int detachstate;
   int inheritsched;

   s = pthread_attr_getstacksize(attr, &stacksize);
   if (s != 0)
       errExitEN(s, "pthread_attr_getstacksize");
   printf("Stack size:          %zd\en", stacksize);

   s = pthread_attr_getguardsize(attr, &guardsize);
   if (s != 0)
       errExitEN(s, "pthread_attr_getguardsize");
   printf("Guard size:          %zd\en", guardsize);

   s = pthread_attr_getschedpolicy(attr, &policy);
   if (s != 0)
       errExitEN(s, "pthread_attr_getschedpolicy");
   printf("Scheduling policy:   %s\en",
           (policy == SCHED_FIFO) ? "SCHED_FIFO" :
           (policy == SCHED_RR) ? "SCHED_RR" :
           (policy == SCHED_OTHER) ? "SCHED_OTHER" : "[unknown]");

   s = pthread_attr_getschedparam(attr, &schedparam);
   if (s != 0)
       errExitEN(s, "pthread_attr_getschedparam");
   printf("Scheduling priority: %d\en", schedparam.sched_priority);

   s = pthread_attr_getdetachstate(attr, &detachstate);
   if (s != 0)
       errExitEN(s, "pthread_attr_getdetachstate");
   printf("Detach state:        %s\en",
           (detachstate == PTHREAD_CREATE_DETACHED) ? "DETACHED" :
           (detachstate == PTHREAD_CREATE_JOINABLE) ? "JOINABLE" :
           "???");

   s = pthread_attr_getinheritsched(attr, &inheritsched);
   if (s != 0)
       errExitEN(s, "pthread_attr_getinheritsched");
   printf("Inherit scheduler:   %s\en",
           (inheritsched == PTHREAD_INHERIT_SCHED) ? "INHERIT" :
           (inheritsched == PTHREAD_EXPLICIT_SCHED) ? "EXPLICIT" :
           "???");
}

int
main(int argc, char *argv[])
{
   int s;
   pthread_attr_t attr;

   s = pthread_getattr_default_np(&attr);
   if (s != 0)
       errExitEN(s, "pthread_getattr_default_np");

   display_pthread_attr(&attr);

   exit(EXIT_SUCCESS);
}
0

评论区