不操千曲而后晓声,观千剑而后识器。这篇文章主要讲述Linux 内核线程调度示例一 ④ ( pthread_attr_init 初始化线程属性对象 | 完整代码示例 )相关的知识,希望能为你提供帮助。
文章目录
- ??一、pthread_attr_init 初始化线程属性对象??
- ??二、完整代码示例??
一、pthread_attr_init 初始化线程属性对象
在之前的博客
- ??【Linux 内核】线程调度示例一 ① ( 获取线程调度策略 | 断言 assert | 代码示例 )??
- ??【Linux 内核】线程调度示例一 ② ( 获取指定调度策略的最大和最小优先级 | 代码示例 )??
- ??【Linux 内核】线程调度示例一 ③ ( 获取线程优先级 | 设置线程调度策略 | 代码示例 )??
下面的 main 函数 , 调用上述方法 , 实现了对线程的 调度策略 和 优先级 操作 ;
【Linux 内核线程调度示例一 ④ ( pthread_attr_init 初始化线程属性对象 | 完整代码示例 )】
?
?pthread_attr_init?
?? 函数作用是 初始化一个 线程对象的属性 , 使用完毕后 , 需要调用 ??pthread_attr_destroy?
? 函数销毁 线程属性 ;
#include < pthread.h>
int pthread_attr_init(pthread_attr_t *attr);
main 函数代码示例 :
int main(int argc, char *argv)
// 线程属性结构体
pthread_attr_t p_attr;
// 调度相关参数
struct sched_param sched;
// 初始化线程参数
int ret = pthread_attr_init(& p_attr);
// 确保线程参数初始化成功
assert(ret == 0);
// 获取线程调度策略, SCHED_OTHER 是普通进程
// SCHED_OTHER 类型调度策略
int policy = get_thread_policy(& p_attr);
printf("\\n输出当前 SCHED_OTHER 调度策略优先级:\\n");
// 打印当前线程的优先级
// 0 调度策略的 最大优先级为 0
// 0 调度策略的 最小优先级为 0
print_thread_priority_with_policy(& p_attr, policy);
printf("\\n输出 SCHED_FIFO 调度策略优先级:\\n");
// 打印当前线程的优先级
// 1 调度策略的 最大优先级为 99
// 1 调度策略的 最小优先级为 1
print_thread_priority_with_policy(& p_attr, SCHED_FIFO);
printf("\\n输出 SCHED_RR 调度策略优先级:\\n");
// 打印当前线程的优先级
// 2 调度策略的 最大优先级为 99
// 2 调度策略的 最小优先级为 1
print_thread_priority_with_policy(& p_attr, SCHED_RR);
// 获取当前线程的优先级
// 获取的线程优先级为 -879536928
// 打印出来是一个随机数 , 只有 实时调度策略 时 , 优先级才有效
printf("\\n输出当前线程的优先级:\\n");
get_thread_priority(& p_attr);
printf("\\n设置当前线程调度策略为 SCHED_FIFO :\\n");
set_thread_policy(& p_attr, SCHED_FIFO);
printf("\\n设置当前线程调度策略为 SCHED_RR :\\n");
set_thread_policy(& p_attr, SCHED_RR);
// 销毁 线程属性 结构体
ret = pthread_attr_destroy(& p_attr);
assert(ret == 0);
printf("\\nmain 函数执行完毕 !\\n");
return 0;
二、完整代码示例
完整代码示例 :
#include < stdio.h>
#include < unistd.h>
#include < stdlib.h>
#include < pthread.h>
#include < assert.h>
/**
* @brief 获取线程调度策略
*
* @return int
*/
static int get_thread_policy(pthread_attr_t *p_attr)
// 用于接收调度策略返回值
int policy;
// 获取线程的调度策略, 如 SCHED_FIFO, SCHED_RR, SCHED_OTHER
int ret = pthread_attr_getschedpolicy(p_attr, & policy);
// 断言操作 , 保证下面的代码正常执行 , 如果 ret == 0 继续执行 , 否则进程退出
assert(ret == 0);
// 打印调度策略
switch (policy)
case SCHED_FIFO:
printf("SCHED_FIFO 类型调度策略\\n");
break;
case SCHED_RR:
printf("SCHED_RR 类型调度策略\\n");
break;
case SCHED_OTHER:
printf("SCHED_OTHER 类型调度策略\\n");
break;
default:
printf("未知类型调度策略 %d\\n", policy);
break;
return policy;
/**
* @brief 打印指定调度策略的最大和最小优先级
*
* @return int
*/
static int print_thread_priority_with_policy(pthread_attr_t *p_attr, int policy)
// 用于接收调度策略最大优先级返回值
int priority_max;
// 获取指定调度策略的最大优先级
priority_max = sched_get_priority_max(policy);
// 获取失败会返回 -1
assert(priority_max != -1);
printf("%d 调度策略的 最大优先级为 %d\\n", policy, priority_max);
// 用于接收调度策略最小优先级返回值
int priority_min;
// 获取指定调度策略的最小优先级
priority_min = sched_get_priority_min(policy);
// 获取失败会返回 -1
assert(priority_min != -1);
printf("%d 调度策略的 最小优先级为 %d\\n", policy, priority_min);
return 0;
/**
* @brief 获取线程优先级
*
* @return int
*/
static int get_thread_priority(pthread_attr_t *p_attr)
// 获取调度参数
struct sched_param param;
// 获取线程调度优先级
int ret = pthread_attr_getschedparam(p_attr, & param);
// 确保获取优先级操作执行成功,如果执行失败,则退出程序
assert(ret == 0);
printf("获取的线程优先级为 %d\\n", param.sched_priority);
return param.sched_priority;
/**
* @brief 设置线程调度策略
*
* @return int
*/
static int set_thread_policy(pthread_attr_t *p_attr, int policy)
// 设置线程调度策略
int ret = pthread_attr_setschedpolicy(p_attr, policy);
// 确保获取优先级操作执行成功,如果执行失败,则退出程序
assert(ret == 0);
// 验证线程是否设置调度策略成功, 打印调度策略
get_thread_policy(p_attr);
return 0;
int main(int argc, char *argv)
// 线程属性结构体
pthread_attr_t p_attr;
// 调度相关参数
struct sched_param sched;
// 初始化线程参数
int ret = pthread_attr_init(& p_attr);
// 确保线程参数初始化成功
assert(ret == 0);
// 获取线程调度策略, SCHED_OTHER 是普通进程
// SCHED_OTHER 类型调度策略
int policy = get_thread_policy(& p_attr);
printf("\\n输出当前 SCHED_OTHER 调度策略优先级:\\n");
// 打印当前线程的优先级
// 0 调度策略的 最大优先级为 0
// 0 调度策略的 最小优先级为 0
print_thread_priority_with_policy(& p_attr, policy推荐阅读
- Linux 内核 内存管理RCU 机制 ① ( RCU 机制简介 | RCU 机制的优势与弊端 | RCU 机制的链表应用场景 )
- Terraform与Kubernetes的体验
- Linux 内核 内存管理优化内存屏障 ④ ( 处理器内存屏障 | 八种处理器内存屏障 | 通用内存屏障 | 写内存屏障 | 读内存屏障 | 数据依赖屏障 | 强制性内存屏障
- Tomcat实战案例(yum和二进制安装)
- FTP连接的详细步骤及连接模式
- HiSpark IPC Camera开发环境搭建(基于V1.1.4)
- Linux 内核 内存管理RCU 机制 ② ( RCU 机制适用场景 | RCU 机制特点 | 使用 RCU 机制保护链表 )
- Spring Framework RCE CVE-2022-22965漏洞学习
- Shell中的${},##和%%的使用简单介绍