信号量在Linux多线程机制中应用.doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
信号量在Linux多线程机制中应用

信号量在Linux多线程机制中应用   【摘 要】本文以信号量原理为基础,重点阐述信号量在Linux多线程同步机制中的实现特色。 【关键词】信号量;Linux;多线程;同步 1 信号量 1965年E. W. Dijkstra首次提出信号量的概念,用于解决进程间同步或互斥的多方协调运行问题,因其工作时交换信息量较少,故将其归类为进程的低级通信方式,有别于管道通信、消息传递等能传输大量数据的高级通信方式。操作系统引入多线程机制后,信号量也广泛应用于多线程的同步与协调,避免多个线程同时进入临界区而造成的运行结果不确定。 通常信号量使用一个整型变量表示,进程(或是线程)只能对其实施两个操作:P操作和V操作,前者可使信号量的值减1,后者则对信号量值加1。进程间若存在有直接制约(逻辑次序关系)关系,则执行顺序在前的进程执行完毕需使用V操作发出信号,而顺序在后的进程执行前需使用P操作检查信号。若进程间存在的是间接制约(竞争临界资源)关系,则使用资源之前需执行P操作检查资源状态是否可用,即申请资源,若P操作成功,则执行临界区,执行完毕退出临界区,使用V操作释放资源。此处,P操作会面临失败的可能,那么对应执行的进程会进入与信号量挂钩的一个等待队列,即转入等待状态,直到其他进程通过V操作释放资源,从而唤醒等待进程继续执行。 2 Linux系统下的多线程 Linux线程属于核心级线程,但其实现方式比较特别,每个线程对内核来说都是一个进程。LinuxThreads是目前Linux平台上使用最为广泛的线程库,采用基于内核支持轻量级进程支持的线程一对一模型,即每个线程依赖于一个内核轻量级进程的模式,由核心完成线程调度,同时在核外函数库中实现诸如线程同步互斥、线程创建取消等线程管理工作。在LinuxThreads中,每一个进程都一个对应的管理线程,负责处理线程相关的管理工作。当进程第一次调用pthread_create( )创建一个线程的时候就会调用__clone( )并启动管理线程。 Linux提供两种信号量:1)内核信号量,由内核控制路径使用;2)用户态进程使用的信号量,这种信号量又分为POSIX信号量和SYSTEM V信号量。POSIX信号量又分为有名信号量和无名信号量。有名信号量,其值保存在文件中,所以它可以用于线程也可以用于进程间的同步。无名信号量,其值保存在内存中。对POSIX来说,信号量是个非负整数,常用于线程间同步。而SYSTEM V信号量则是一个或多个信号量的集合,它对应的是一个信号量结构体,这个结构体是为 SYSTEM V IPC服务的,信号量只不过是它的一部分,常用于进程间同步。 本文的研究将主要围绕内核信号量及无名信号量在实现多线程同步上的应用。 3 内核信号量 3.1 内核信号量的相关函数 3.1.1 初始化 1)void sema_init (struct semaphore *sem, int val); 2)void init_MUTEX(struct semaphore *sem); //将sem的值置1,表示资源空闲 3)void init_MUTEX_LOCKED(struct semaphore *sem); //将sem的值置为0,表示资源忙 3.1.2 申请内核信号量所保护的资源 1)void down(struct semaphore * sem); // 可引起睡眠 2)int down_interruptible(struct semaphore*sem); // down_interruptible能被信号打断 3)int down_trylock(struct semaphore * sem); // 非阻塞函数,不会睡眠。无法锁定资源则马上返回 3.1.3 释放内核信号量所保护的资源 1)void up(struct semaphore * sem); 3.2 内核信号量的使用例程 在驱动程序中,当多个线程同时访问相同的资源时(驱动中的全局变量时一种典型的共享资源),可能会引发“竞态“,因此我们必须对共享资源进行并发控制。Linux内核中解决并发控制的最常用方法是自旋锁与信号量(绝大多数时候作为互斥锁使用)。 ssize_t globalvar_write(struct file *filp, const char *buf, size_t len, loff_t *off) { //获得信号量 if (down_interruptible(sem)) { return - ERESTARTSYS; } //将用户空间的数

文档评论(0)

docman126 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档