互斥锁问题
2015-07-30 15:16
363 查看
互斥锁保证每时刻每个用户看到的共享数据是一样的。只有lock与unlock两种状态,确保同一时间只有一个线程访问数据。
在同一时间通常只允许一个线程执行部分代码。
使用互斥锁前必须进行初始化操作。
(1)pthread_mutex_t = PTHREAD_MUTEX_INITIALIZER;
(2)int pthread_mutex_init (pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr);
互斥锁锁住的并不是一个变量,而是阻塞一段程序。如果对一个mutex变量执行了第一次lock之后,在unlock前的这短时间内,如果有其他线程也只行到了lock,这个线程就会阻塞住,知道之前的lock解锁之后才能执行。
加锁:
int pthread_mutex_lock(pthread_mutex_t *mutex);
int pyhread_mutex_trylock(pthread_mutex_t *mutex);
若mutex已经被加锁则lock会等带其解锁再加锁运行后面的程序,而trylock若遇到mutex以加锁则立即返回返回的错误代码为EBUSY,而不是阻塞等待。
解锁:
int pthread_mutex_unlock(pthread_mutex_t *mutex);
解锁时需要满足两个条件,一时互斥锁处于加锁状态,二是调用unlock的线程必须是给互斥锁加锁的线程;
int pthread_thread_delete(pthread_mutex_destory);
清楚一个互斥锁意味着释放其占有的资源清除锁时要求当前处于开放状态。
在同一时间通常只允许一个线程执行部分代码。
使用互斥锁前必须进行初始化操作。
(1)pthread_mutex_t = PTHREAD_MUTEX_INITIALIZER;
(2)int pthread_mutex_init (pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr);
互斥锁锁住的并不是一个变量,而是阻塞一段程序。如果对一个mutex变量执行了第一次lock之后,在unlock前的这短时间内,如果有其他线程也只行到了lock,这个线程就会阻塞住,知道之前的lock解锁之后才能执行。
加锁:
int pthread_mutex_lock(pthread_mutex_t *mutex);
int pyhread_mutex_trylock(pthread_mutex_t *mutex);
若mutex已经被加锁则lock会等带其解锁再加锁运行后面的程序,而trylock若遇到mutex以加锁则立即返回返回的错误代码为EBUSY,而不是阻塞等待。
解锁:
int pthread_mutex_unlock(pthread_mutex_t *mutex);
解锁时需要满足两个条件,一时互斥锁处于加锁状态,二是调用unlock的线程必须是给互斥锁加锁的线程;
int pthread_thread_delete(pthread_mutex_destory);
清楚一个互斥锁意味着释放其占有的资源清除锁时要求当前处于开放状态。
相关文章推荐
- hd2199 Can you solve this equation?
- Milk
- pcap文件格式分析
- Java compiler level does not match解决方法
- Hibernate懒加载异常
- 数据库 - 第三范式(3NF)
- 几个测试远端ip,端口,端口占用情况的命令总结
- [转]activiti5用户任务分配
- SVG实战开发学习(四)——坐标系统与坐标轴转换
- 《javascript高级程序设计》对象图
- 黑马程序员-面试题(一)-交通灯管理系统
- php实现json编码的方法
- 字符个数统计
- Oracle 学习之RMAN(五)镜像copy
- 不用安装ORACLE客户端(不执行*.exe)也能使用PL/SQL Developer的说明
- Linux - man page
- 遥感知识网站
- Linux - man page
- 秘Java虚拟机——内存管理与垃圾回收
- SQL join