线程同步与异步
来源:互联网 发布:数据的指标分析体系 编辑:程序博客网 时间:2024/04/28 22:37
打个比方,如果你在等一个人,
同步的时候,你会一直等到她来了之后才做其他事情,这个过程除了等待你啥都不会做, 异步的时候,你一边在等,可能一边玩游戏或者是看报纸什么的,一直到她到来,你的等待状态才会结束
在实现上,同步的过程会阻塞进程的所有其他操作,将同步转换为异步的最常见方法则是 将会阻塞进程的等待操作放入到一个新的进程中,同时为该等待操作添加一个监视器,在检测到等待操作完成的时候结束等待的进程。
二、区别同步和异步
一个进程启动的多个不相干线程,它们相互之间关系为异步。
举个简单的例子 就是游戏,游戏会有图像和背景音乐
图像是由玩家操作的 而背景音乐一般都是循环播放玩家不能操作
这里的图像和声音就分别是不同的线程 图像一般是主线程 背景音乐是守护线程(守护线程就是主线程结束的时候守护线程也结束) 像这样的组合就是异步线程 两个线程之间没什么关系各干各的
.至于同步的话指的是多线程同时操作一个数据 这个时候需要对数据添加保护 这个保护就是线程的同步
三、同步机制
临界区、互斥区、事件、信号量四种方式
临界区(Critical Section)、互斥量(Mutex)、信号量(Semaphore)、事件(Event)的区别
1、临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。在任意时刻只允许一个线程对共享资源进行访问,如果有多个线程试图访问公共资源,那么在有一个线程进入后,其他试图访问公共资源的线程将被挂起,并一直等到进入临界区的线程离开,临界区在被释放后,其他线程才可以抢占。
2、互斥量:采用互斥对象机制。 只有拥有互斥对象的线程才有访问公共资源的权限,因为互斥对象只有一个,所以能保证公共资源不会同时被多个线程访问。互斥不仅能实现同一应用程序的公共资源安全共享,还能实现不同应用程序的公共资源安全共享
3、信号量:它允许多个线程在同一时刻访问同一资源,但是需要限制在同一时刻访问此资源的最大线程数目
4、事 件: 通过通知操作的方式来保持线程的同步,还可以方便实现对多个线程的优先级比较的操作
- 线程同步与异步
- 线程同步与异步
- 线程同步与异步
- 线程同步与异步
- 线程的同步与异步
- java线程 同步与异步
- 线程的同步与异步
- java线程 同步与异步
- 线程的同步与异步
- 线程中的同步与异步
- 线程的同步与异步
- 线程的同步与异步
- java线程 同步与异步
- java线程 同步与异步 线程池
- java线程 同步与异步 线程池
- java线程 同步与异步 线程池
- 同步与异步 线程与多线程
- 同步与异步 线程与多线程
- Keybindings in ATOM
- Message Queue - MQ Intro
- jQuery如何设置checkbox选中状态
- 没留下任何外链地址,也没向百度谷歌提交收录,为什么就收录了的呢?
- Edmonds-Karp算法,网络流最大流
- 线程同步与异步
- SPL学习笔记(4)---基础接口
- js如何实现继承
- J2EE学习路程-JDBC学习笔记
- opencv关于imread读不到图像的问题
- window.oepn()
- IOS 个推推送总结
- 什么是GLEW GLFW GLM
- ThinkPHP Where 条件中使用表达式