linux io 学习笔记(01)---锁,信号量
1.采用信号量访问:当有段临界代码,需要保证排他的访问一个资源。
2.sudo dmesg -c 消除dmesg缓冲
3.互斥锁:代表的是一种锁资源,互斥锁的工作原理是:保证对共享资源操作的原子性
4.自旋锁:轮循
5.读写锁:奇偶
6.顺序锁:读写可并发,但是会检测信号
互斥锁中:
死锁:(1)互斥锁交叉嵌套
(2)同一个互斥锁嵌套使用
(3)占有锁资源的任务被异常退出,锁资源不会释放,比如,一个线程开了一个锁,还没来得及解锁,线程就被取消了。
避免死锁:申请锁,按顺序加锁,以防死锁。
7,锁和信号量不一样,比如要顺序执行时。
1).初始化互斥锁
函数原型: int pthread_mutex_init(pthread_mutex_t *restrict mutex,
const pthread_mutexattr_t *restrict attr);
功能: 初始化互斥锁
参数: mutex 互斥锁的标识符
attr 互斥锁的属性 NULL
返回值: 成功:0
失败 :错误码
2):执行上锁:
函数原型:int pthread_mutex_lock(pthread_mutex_t *mutex);
功能: 执行上锁操作
参数: mutex 互斥锁的标识符
返回值: 成功 0
失败:错误码
3):执行解锁
函数原型: int pthread_mutex_unlock(pthread_mutex_t *mutex);
功能:执行解锁操作
参数: mutex 互斥锁的标识符
返回值:成功 0 ;失败:错误码;
4):释放锁资源:
函数原型:int pthread_mutex_destroy(pthread_mutex_t *mutex);
功能: 摧毁锁资源
参数: mutex互斥锁的标识符
返回值: 成功0
失败:错误码
信号量:
申请信号量:p操作 -1
释放信号量:v操作 +1
当执行任务,申请信号量时,如果当前信号量的值大于0,申请成功,信号量减一,不大于0 则申请失败。会阻塞。
1)初始化信号量的值
int sem_init(sem_t *sem, int pshread,unsigned int value);
功能: 初始化信号量
参数:sem 信号量的标识符
pashred 0 用于线程间
非0 用于进程间
value 信号量的初始值
返回值: 成功 0
失败 -1
2)申请信号量
int sem_wait(sem_t *sem);
功能:申请信号量,信号量的值-1;
参数:sem 信号量的标识符
返回值:成功 0
失败 -1
3)释放信号量
int sem_post(sem_t *sem);
功能:释放信号量 信号量的值+1;
参数:sem 信号量的标识符
返回值 成功 0
失败 -1
4)摧毁信号量
int sem_destroy(sem_t *sem);
参数: sem 信号量的标识符
返回值: 成功 0
失败 -1
5)获取当前信号量的值
int sem_getvalue(sem_t *sem,int *sval);
参数: sem:信号量的标识符
sval 保存当前信号量的值。
linux io 学习笔记(01)---锁,信号量的更多相关文章
- Linux Basic学习笔记01
介绍课程: 中级: 初级:系统基础 中级:系统管理.服务安全及服务管理.Shell脚本: 高级: MySQL数据库: cache & storage 集群: Cluster lb: 4laye ...
- linux io 学习笔记(02)---条件变量,管道,信号
条件变量的工作原理:对当前不访问共享资源的任务,直接执行睡眠处理,如果此时需要某个任务访问资源,直接将该任务唤醒.条件变量类似异步通信,操作的核心:睡眠.唤醒. 1.pthread_cond_t 定 ...
- linux c学习笔记----互斥锁属性
转自:http://lobert.iteye.com/blog/1762844 互斥锁属性 使用互斥锁(互斥)可以使线程按顺序执行.通常,互斥锁通过确保一次只有一个线程执行代码的临界段来同步多个线程. ...
- linux io 学习笔记(03)---共享内存,信号灯,消息队列
system V IPC 1)消息队列 2)共享内存 3)信号灯(信号量集) 1.消息队列. ipcs -q 查看系统中使用消息队列的情况 ipcrm -q +msqid 删除消息队列 消息队列工作原 ...
- linux shell 学习笔记01
1.命令历史记录history !$ :调用上一条命令的执行结果 !100 :运行history记录里的第100条命令 !ser :调用以ser开头的最后一次执行的命令 ctrl+r ...
- linux kernel学习笔记-5内存管理_转
void * kmalloc(size_t size, gfp_t gfp_mask); kmalloc()第一个参数是要分配的块的大小,第一个参数为分配标志,用于控制kmalloc()的行为. km ...
- Linux系统学习笔记:文件I/O
Linux支持C语言中的标准I/O函数,同时它还提供了一套SUS标准的I/O库函数.和标准I/O不同,UNIX的I/O函数是不带缓冲的,即每个读写都调用内核中的一个系统调用.本篇总结UNIX的I/O并 ...
- Java IO学习笔记一
Java IO学习笔记一 File File是文件和目录路径名的抽象表示形式,总的来说就是java创建删除文件目录的一个类库,但是作用不仅仅于此,详细见官方文档 构造函数 File(File pare ...
- C++ GUI Qt4学习笔记01
C++ GUI Qt4学习笔记01 qtc++signalmakefile文档平台 这一章介绍了如何把基本的C++只是与Qt所提供的功能组合起来创建一些简单的图形用户界面应用程序. 引入两个重要概 ...
随机推荐
- web中的cookie管理
本篇是以JSP为背景介绍,但是在web开发中也是相同的原理. 什么是cookie 由于http是一种无状态的协议,因此服务器收到请求后,只会当做一次新的请求.即便你重复发送了1000次同样的请求,这1 ...
- 4.Zabbix 3.0 案例
请查看我的有道云笔记: http://note.youdao.com/noteshare?id=2807c0910cd63d309e1462128a31ae0e&sub=241A94E5717 ...
- The content of element type "bean" must match "(description?,(constructor-arg|property|lookup-method|replaced-method)*)".
开发中,总有一下奇奇怪怪的问题 完整的错误就不贴了,异常提示: hibernate.xml] is invalid; nested exception is org.xml.sax.SAXParseE ...
- What is Thread
A thread is a fundamental unit of CPU utilization –a thread ID –a program counter –a register set –a ...
- Django:Django中的ORM
一.Django项目使用MySQL数据库 1,在Django项目的settings.py,文件中,配置数据库连接信息: DATABASES = { "default": { &qu ...
- 使用TimeSpan对象获取时间间隔
实现效果: 关键知识: TimeSpan对象表是时间间隔或持续时间,两个DateTime对象相减,则会得到一个TimeSpan对象 使用其days ,hours,minutes等属性 实现代码: pr ...
- MR中简单实现自定义的输入输出格式
import java.io.DataOutput; import java.io.IOException; import java.util.HashMap; import java.util.Ma ...
- 优雅的QSignleton (一) Singleton单例实现
接下来笔者来介绍如何用QSingleton实现一个简单的单例. 代码如下. Singleton.cs namespace QFramework.Example { using UnityEngine; ...
- 搭建Hadoop2.6.0+Eclipse开发调试环境
上一篇在win7虚拟机下搭建了hadoop2.6.0伪分布式环境.为了开发调试方便,本文介绍在eclipse下搭建开发环境,连接和提交任务到hadoop集群. 1. 环境 Eclipse版本Luna ...
- zepto 基础知识(3)
41.height height() 类型:number height(value) 类型:self height(function(index,oldHeight){...}) 类型:self 获取 ...