linux 互斥锁销毁_Linux线程互斥学习笔记--详细分析转

一、互斥锁为啥要有互斥?多个进程/线程执行的先后顺序不确定,何时切出CPU也不确定。多个进程/线程访问变量的动作往往不是原子的。1. 操作步骤(1)创建锁// 创建互斥锁mutexpthread_mutex_t mutex;(2)初始化锁在Linux下, 线程的互斥量数据类型是pthread_mutex_t 在使用前, 要对它进行初始化:初始化的两种方法:(推荐使用第二种)1.静态分配pthrea...
摘要由CSDN通过智能技术生成

一、互斥锁

为啥要有互斥?

多个进程/线程执行的先后顺序不确定,何时切出CPU也不确定。

多个进程/线程访问变量的动作往往不是原子的。

1. 操作步骤

(1)创建锁

// 创建互斥锁mutex

pthread_mutex_t mutex;

(2)初始化锁

在Linux下, 线程的互斥量数据类型是pthread_mutex_t 在使用前, 要对它进行初始化:

初始化的两种方法:(推荐使用第二种)

1.静态分配

pthread_mutex mutex = PTHREAD_MUTEX_INITIALIZER;

2.动态分配

int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);

mutex: 要初始化的互斥量(restrict的作用是告诉调用者,不要改变指针的指向)

attr:锁的属性,一般写NULL

加restrict的作用:只用于修饰函数参数里的指针,这个指针会频繁使用,所以把这个地址放到寄存器里,用着好找。

①设置线程的属性

int pthread_attr_init(pthread_attr_t *attr);//初始化线程属性

int pthread_attr_destroy(pthread_attr_t *attr);//销毁线程属性

Thread attributes(线程属性):

线程的分离属性: Detach state=PTHREAD_CREATE_DETACHED

线程的竞争范围: Scope = PTHREAD_SCOPE_SYSTEM

是否继承调度策略: Inherit scheduler = PTHREAD_EXPLICIT_SCHED

调度策略: Scheduling policy = SCHED_OTHER

调度优先级: Scheduling priority = 0

线程栈之间的保留区域: Guard size = 4096 bytes

自己指定栈地址: Stack address = 0x40197000

栈大小: Stack size = 0x3000000 bytes

//设置线程的分离属性

int pthread_attr_setdetachstate(pthread_attr_t *attr, int detachstate);

//detachstate:有以下两种选择

PTHREAD_CREATE_DETACHE

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值