线程同步和异步区别 同步机制

线程同步和线程异步有什么区别?(重要基础知识)
打个比方,如果你在等一个人,
同步的时候,你会一直等到她来了之后才做其他事情,这个过程除了等待你啥都不会做,
异步的时候,你一边在等,可能一边玩游戏或者是看报纸什么的,一直到她到来,你的等待状态才会结束
在实现上,同步的过程会阻塞进程的所有其他操作,将同步转换为异步的最常见方法则是
将会阻塞进程的等待操作放入到一个新的进程中,同时为该等待操作添加一个监视器,在检测到等待操作完成的时候结束等待的进程。

同步就是指一个线程要等待上一个线程执行完之后才开始执行当前的线程

异步是指一个线程去执行,它的下一个线程不必等待它执行完就开始执行

1 区别同步和异步
一个进程启动的多个不相干线程,它们相互之间关系为异步。

举个简单的例子 就是游戏,游戏会有图像和背景音乐 
图像是由玩家操作的 而背景音乐一般都是循环播放玩家不能操作 
这里的图像和声音就分别是不同的线程   图像一般是主线程 背景音乐是守护线程(守护线程就是主线程结束的时候守护线程也结束)  像这样的组合就是异步线程 两个线程之间没什么关系各干各的 
.至于同步的话指的是多线程同时操作一个数据 这个时候需要对数据添加保护 这个保护就是线程的同步
2 同步机制
临界区、互斥区、事件、信号量四种方式
临界区(Critical Section)、互斥量(Mutex)、信号量(Semaphore)、事件(Event)的区别 
1、临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。在任意时刻只允许一个线程对共享资源进行访问,如果有多个线程试图访问公共资源,那么在有一个线程进入后,其他试图访问公共资源的线程将被挂起,并一直等到进入临界区的线程离开,临界区在被释放后,其他线程才可以抢占。 
2、互斥量:采用互斥对象机制。 只有拥有互斥对象的线程才有访问公共资源的权限,因为互斥对象只有一个,所以能保证公共资源不会同时被多个线程访问。互斥不仅能实现同一应用程序的公共资源安全共享,还能实现不同应用程序的公共资源安全共享 
3、信号量:它允许多个线程在同一时刻访问同一资源,但是需要限制在同一时刻访问此资源的最大线程数目 
4、事 件: 通过通知操作的方式来保持线程的同步,还可以方便实现对多个线程的优先级比较的操作

1、首先明确一点,对于单核CPU,任意一个时刻只有一个线程在运行。那么既然这样,多线程还有什么意义呢? 举例来说,现在只有一个人,要做好几个任务。单线程就是,任务一个一个地做,必须做完一个任务后,再去做另一个任务。多线程就是一会做这个任务,一会做那个任务,每个任务做一会,不停的切换。显然,最后把所有的任务做完,多线程必定比单线程更耗费时间。为什么?因为,多线程要在不同的任务之间切换,切换肯定是要耗费时间的。那么问题来了,既然多线程比单线程更耗费时间,为什么还要多线程? 单线程有一个致命的问题,就是一个线程运行的整个过程中,其他线程必须等待,不能响应用户的命令,用户体验太差,好像电脑死机一样。假如单线程,你能想象一下,用户在听歌的时候不能写文档,这种体验也太差了。多线程的时候,单核CPU一会做这个任务,一会做那个任务,切换的时间是毫秒级的,用户完全感觉不出来。从而给用户照成错觉,感觉这些任务并行的运行。

2、同步的使用场景:多个线程同时访问一块数据,也叫共享区。对于多个线程同时访问一块数据的时候,必须使用同步,否则可能会出现不安全的情况。比如数据库中的脏读。但是,多个线程同时访问一块数据,有一种情况不需要同步技术,那就是原子操作,也就是说操作系统在底层保证了操作要么全部做完,要么不做。

3、异步的使用场景:只有一个线程访问当前的数据。比如,观察者模式,没有共享区,主题发生变化,通知观察者更新,主题继续做自己的事情,不需要等待观察者更新完成后再工作。




  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java线程同步异步指的是线程间如何协作。 同步(Synchronization)是指线程之间的协调,确保每一个时刻只有一个线程执行某段代码。 异步(Asynchronization)是指线程之间不需要协调,多个线程可以同时执行某段代码。 简单来说,同步线程之间互相等待,异步线程之间互不干扰。 ### 回答2: Java线程同步异步是两种不同的多线程编程概念。 线程同步是指多个线程之间按照一定的顺序来共享数据和执行任务,以保证数据的一致性和正确性。在同步过程,一个线程执行到某一点时,其他想要访问该点的线程必须等待,直到执行完毕才能继续执行。同步机制通过synchronized关键字、ReentrantLock等机制来实现,可以避免多个线程同时修改共享数据而导致的数据不一致问题。 而线程异步则是指多个线程之间独立运行,并不按照特定顺序来共享数据和执行任务。每个线程独立执行自己的任务,彼此之间无需等待。线程异步可以提高程序的并发性和性能,但同时也会增加编程复杂度和出错可能性。在异步处理,通常使用线程池或者Future接口等机制来实现异步执行。 综上所述,线程同步异步区别在于线程之间的执行顺序和数据访问方式。同步机制可以保证数据的一致性和正确性,但可能会造成性能问题;而异步机制可以提高并发性和性能,但可能会引发编程复杂度和出错可能性。根据具体的应用场景和需求,选择合适的线程同步异步方式来实现多线程编程。 ### 回答3: Java线程同步异步是两种不同的处理机制线程同步是指多个线程按照一定的顺序执行,其一个线程完成了特定的任务后,其他线程才能继续执行。在Java,可以通过关键字synchronized和Lock来实现线程同步。使用同步机制可以有效地避免多个线程对共享资源的竞争,保证数据的一致性和正确性。然而,线程同步也有一些缺点,比如可能会引起死锁和性能下降。 线程异步是指多个线程可以独立执行,彼此之间不需要等待。每个线程可以以不同的顺序和速度执行任务,因此具有更高的并发性。在Java,可以使用线程池和CompletableFuture等机制来实现线程异步执行。异步编程可以提高程序的响应速度和吞吐量,并提高系统的并发性能。然而,异步编程在处理共享资源时需要额外的注意,因为多个线程可能会并发地访问和修改共享资源,可能引发数据的不一致和竞争条件。 综上所述,线程同步异步是不同的线程处理机制线程同步保证了多个线程按照一定的顺序执行,避免了竞争条件和数据的不一致;而线程异步则可以独立执行,提高了并发性能,但需要额外注意共享资源的并发访问和修改。在实际开发,需要根据具体的需求和场景来选择合适的处理机制
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值