linux操作系统之信号量、互斥量在进程间的同步、文件锁

(1)信号量:进化版的互斥量

         多个线程间对某个对象的部分数据进行共享,使用互斥锁是没有办法实现的,只能将整个数据对象锁住。这样虽然达到了多线程操作数据共享的目的,却导致线程并发性下降。

         信号量:相对折中的一个处理方式,既能保证同步,数据不混乱,又能提高线程开发。

(2)信号量相关函数

          sem_t类型,用来定义信号量。虽然是结构体,使用的时候可以当做整数看待(类似文件描述符)。

           规定信号量不能小于0,信号量的初值,决定了占用信号量的线程的个数。

          头文件在<semaphore.h>

           1)初始化一个信号量:sem_init

                     int  sem_init(sem_t *sem,int pshared,unsigned int value);

                          参数1:信号量

                         参数2:取0表示线程间共享,取1表示进程间

                         参数3;信号量初值

           2)销毁一个信号量:sem_destroy

                   int sem_destroy(sem_t *sem);

          3)给信号量加锁:sem_wait(信号量初值--)

                   int sem_wait(sem_t *sem);

          4)给信号量解锁:sem_post(信号量初值++)

                   int sem_post(sem_t *sem);

          5)尝试对信号量加锁:sem_trywait

                   int sem_trywait(sem_t *sem);

          6)限时尝试给信号量加锁:sem_timedwait

                   int sem_timedwait(sem_t *sem,const struct timespec*abs_timeout);

(3)进程间同步

             进程间也可以通过互斥锁来达到同步,但必须在pthread_mutex_init初始胡之前,修改其属性为进程间共享。

              pthread_mutexattr_t mattr类型,用来定义mutex锁的属性,修改mutex锁属性函数。

                   1)初始化一个mutex属性对象:pthread_mutexattr_init

                                 int pthread_mutexattr_init(pthread_mutexattr_t *attr);

                   2)销毁一个mutex属性对象:pthread_mutexattr_destroy

                                   int pthread_mutexattr_destroy(pthread_mutexattr_t *attr); 

                   3)修改mutex属性

                                  int pthread_mutexattr_setpshared(pthread_mutexattr_t *attr , int pshared); 

                            参数2:取值:

                                           线程锁:PTHREAD_PROCESS_PRIVATE(mutex默认属性,进程间私有);

                                           进程锁:PTHREAD_PROCESS_SHARED

(4)使用进程锁完成同步

                

                             

(5)文件锁

                借助fcntl来实现锁机制。操作文件的进程没有获得锁时 ,可以打开,但无法执行read/write操作

                         fcntl函数:获取和修改文件访问控制属性

                 int fcntl(int fd,int cmd,.../*arg*/);

                          参数2:F_SETLK:设置文件锁(trylock)           

                                        F_SETLKW 设置文件锁(wait)

                                        F_GETLK 获取文件锁

                         参数3:

                                    struct flock{

                                                   ..... 

                                                    short l_type;//锁的类型:F_RDLCK,F_WRLCK,F_UNLCK(解锁);

                                                    short l_whence;//偏移位置,SEEK_SET,SEEK_CUR,SEEK_END

                                                    off_t l_start;//起始偏移量

                                                    off_t l_len;  //加锁数据的长度,len=0,对整个文件加锁

                                                    pid_t l_pid;//持有该锁的进程ID:(F_GETLK only)

                                                  ...

                                       };

(6)进程间文件锁

     

(7)多线程中,能否使用文件锁?

                   多线程之间共享文件描述符,而给文件加锁,是通过修改文件描述符所指向的文件结构体中的成员变量来实现的。因此线程之间无法使用文件锁。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/382311.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux网络编程之网络应用设计模式、分层模型、通信过程

&#xff08;1&#xff09;网络协议 可以理解为规则&#xff0c;其中包含着数据传输和数据的解释。 典型的协议&#xff1a;传输层&#xff1a;tcp/udp协议&#xff0c;应用层&#xff1a;http/ftp协议&#xff0c;网络层&#xff1a;ip协议&#xff0c;网路接口&#xff1a;ar…

linux网络编程之通信协议格式

好文参考&#xff1a;《网路传输的三张表&#xff1a;MAC地址表&#xff0c;ARP缓存表和路由表》http://www.cnblogs.com/clovn/p/4911212.html &#xff08;1&#xff09;数据包封装 传输层及其一下的机制由内核决定&#xff0c;主要负责通讯的具体细节&#xff1b;应用层由用…

linux网络编程之Socket编程

&#xff08;1&#xff09;socket套接字 1&#xff09;在linux环境下&#xff0c;socket用于表示进程间网络通信的特殊文件类型&#xff0c;其本质是内核借助缓冲区形成的伪文件&#xff08;不占磁盘空间&#xff0c;除此之外还有二进制文件&#xff0c;管道&#xff0c;字符文…

Linux操作系统之简易实现server/client

1.首先将出错处理封装成函数&#xff0c;具体封装思想&#xff1a;是在底层函数的基础上将首字母大写&#xff08;方便在编程中查找函数文件的manpage,而不需要使用命令&#xff0c;直接用shiftk&#xff09;,然后调用底层库函数并考虑出错处理&#xff0c;具体函数如下&#x…

linux网络编程之TCP三次握手和四次挥手

1.在TCP连接的过程中&#xff0c;有三个阶段&#xff0c;分别是建立连接&#xff0c;传递数据和断开连接&#xff0c;通讯时序图如下所示: 2.结合TCP数据报格式分析建立连接的三次握手 1&#xff09;首先客户端发送一个带有SYN标志的TCP报文给服务器端&#xff0c;询问服务器端…

linux网路编程之多进程并发服务器

1&#xff09;使用多进程并发服务器考虑的因素&#xff1a; &#xff08;1&#xff09;父进程描述最大文件描述符的个数&#xff08;父进程需要关闭accept返回的新文件描述符&#xff09; &#xff08;2&#xff09;系统内可创建进程的个数&#xff08;与内存大小相关&#xff…

linux网路编程之多线程并发服务器

1&#xff09;在使用进程模型开发服务器过程中考虑以下问题 &#xff08;1&#xff09;调整进程内最大文件描述符上限 &#xff08;2&#xff09;线程如有共享&#xff0c;考虑线程同步 &#xff08;3&#xff09;客户端线程退出时&#xff0c;做退出处理&#xff08;线程分离&…

linux网路编程之TCP状态转换及端口复用

&#xff08;1&#xff09;TCP状态转换图 其中图中分为三种状态&#xff1a;实线代表的主动发起连接&#xff0c;虚线代表的被动发起连接&#xff0c;细实线代表的可以双向发起连接的状态。 主动发起连接方状态变化&#xff1a;1&#xff09;主动发起连接的一方发送SYN标志位&…

linux网络编程之多路I/o转接服务器select

(1)多路IO转接服务器也叫做多任务IO服务器&#xff0c;其主要思想是不再由程序自己监听客户端连接&#xff0c;取而代之的是由内核替应用程序监视文件&#xff0c;具体实现模型如图所示&#xff1a; 当客户端请求和服务器连接时&#xff0c;内核接收到连接指令&#xff0c;告诉…

linux网络编程之多路I/O转接服务器poll函数

&#xff08;1&#xff09;poll函数 头文件&#xff1a;#include<poll.h> int poll(struct pollfd*fds, nfds_t nfds,int timeout); struct pollffd{ int fd;//文件描述符 short events;//监控的事件 short revents;//监控事件中满足条件返回的事情 }&#xff1…

《C++ Primer 第五版》第二章(1-4小节)------基本内置类型,初始化和赋值及声明和定义,指针和引用,const和constexpr

C Primer第二章的内容主要介绍了变量和基础类型&#xff0c;包括C语言定义的基础内置类型、变量的定义及声明、符合类型如指针及引用的介绍和const及常量表达式constexpr的介绍&#xff0c;本次博客也从这四个方面进行系统的介绍&#xff0c;如果有不足之处&#xff0c;还望其他…

793. 阶乘函数后K个零 golang

Me(AC 33 / 44 个通过测试用例) func preimageSizeFZF(K int) int {count : 0for i : 0; i < 1000000; i {if trailingZeroes(i) K {count}}fmt.Println(count)//fmt.Println(trailingZeroes(25))return count}func trailingZeroes(n int) int {if n 0 {return 0}return …

小程序radio单选框回显

话不多说&#xff0c;效果图如下&#xff1a; 具体代码如下&#xff1a; <radio-group name"radio" bindchange"getSex"><label><radio value"1" checked"{{xingbie1}}" />男</label><label><radio…

《C++ Primer 第五版》(第4.11节类型转换) ————关于无符号数和有符号数的运算探究

1.关于无符号数和有符号数的运算 关于无符号数和有符号数的运算&#xff0c;在我看来一直是觉得只要有无符号数和有符号数的运算&#xff0c;有符号数就转化为无符号数&#xff0c;但是在《C Primer 第五版》的p142介绍&#xff0c;关于无符号数和有符号数的运算如下规定的&…

543. 二叉树的直径 golang

文章目录543. 二叉树的直径example正确解法question代码&#xff08;wrong)543. 二叉树的直径 概要: 借鉴了这个题的代码。可是有一个测试用例过不去 https://blog.csdn.net/csdn_kou/article/details/104122067 example 给定一棵二叉树&#xff0c;你需要计算它的直径长度。一…

《C++ Primer 第五版》(第4.11-4.12节)——static_cast,const_cast和reinterpret_cast类型转换, 运算符优先级表

1.static_cast,const_cast和reinterpret_cast类型转换 static_cast:强制的类型转换(不能用于底层的const转换),以前C语言中的强制类型转换都可以使用static_cast来完成。如&#xff1a;int i3; double jstatic_cast<double>(i); const_cast&#xff1a;改变底层const(指针…

《C++ Primer 第五版》(第5.1-5.6节) ——异常处理机制(try语句块,throw表达式和catch异常捕捉处理单元)

1. 异常处理机制 C中使用try,throw和catch三个关键字来实现异常的触发、抛出和处理的功能&#xff0c;具体通用语法形式如下&#xff1a; try{ if(true) normal program-statements&#xff1b;//没有触发异常时候执行的代码 if(false) throw(exception); //出现错误&am…

283. 移动零golang

Me 遍历所有数组&#xff0c;统计0的个数倒着把零写入数组末尾 func moveZeroes(nums []int) {var count, j intfor _, key : range nums {if key 0 {count} else{nums[j] keyj}}for i:len(nums) - count; i < len(nums); i {nums[i] 0} }最优解(快慢指针) 减少了数组…

QT自定义MainWindow

1.开发环境&#xff1a;Qt 4.7.3 MinGW 32bit (MSVC2015 32bit) 2.实现大纲&#xff1a; 1&#xff09;自定义边框&#xff0c;标题栏&#xff0c;工具栏&#xff0c;内容栏&#xff0c;状态栏&#xff08;后面三个代码中没有实现实现&#xff09; 2&#xff09;重写鼠标事件…

QTextEdit实现图片和文本同行显示

1.开发环境&#xff1a;Qt 4.7.3 MinGW 32bit (MSVC2015 32bit) 2.实现大纲&#xff1a; 1&#xff09;实现图片和文本在同一行显示&#xff0c;且能够设置字体大小和颜色 2&#xff09;能够手动设置行的宽度和间距 3&#xff09;设置字体样式&#xff0c;然后添加图片&#…