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);
}
评论区