五分钟看穿Java并发相关概念,并发原来如此简单

  • 如果线程1锁住了A,然后尝试对B进行加锁,同时线程2已经锁住了B,接着尝试对A进行加锁,这时死锁就发生了。

  • 线程1永远得不到B,线程2也永远得不到A,并且它们永远也不会知道发生了这样的事情。

  • 为了得到彼此的对象(A和B),它们将永远阻塞下去。这种情况就是一个死锁。

5.并发优点

=========================================================================

5.1.资源利用率高

假定场景:需要从本地读取和处理两个文件,读取一个文件需要5秒,处理一个文件需要2秒。

单线程:

5秒读取文件A

2秒处理文件A

5秒读取文件B

2秒处理文件B


总共需要14秒

多线程:

5秒读取文件A

5秒读取文件B + 2秒处理文件A

2秒处理文件B


总共需要12秒

总结:

  • 在等待磁盘读取文件的时候,CPU大部分时间是空闲的。

  • 利用多线程编程,可以在磁盘读取文件的CPU空闲时间内做一些其他的事情。

  • 所以说, 使用多线程资源利用率更高。

5.2.程序响应更快

一个桌面应用程序存在多个按钮。点击这些按钮,可以分别进行一些耗时的工作。

单线程:

每次点击一个按钮,都会进行一项耗时的工作。必须等待此项工作完成之后,才能继续监听用户操作。这时,用户才能点击其他按钮,进行其他的工作。这样的应用程序,对用户而言,响应十分慢,体验度很差。

多线程:

每次点击一个按钮,都会启动一个子线程去进行这项耗时的工作,主线程继续监听用户操作。这种情况下,用户可以快速的分别点击需要处理的按钮。这样的应用程序,对用户而言,响应很快,体验度很好。

6.并发缺点

=========================================================================

6.1.设计开发更复杂

线程之间的交互往往非常复杂。 不正确的线程同步产生的错误非常难以发现,并且难以重现、难以修复。

6.2.增加额外资源消耗

多线程开发会产生额外的资源消耗,主要来源于三个方面:

  • 线程本身需要消耗一些资源进行本地堆栈的维持与管理。
  • 线程之间切换会导致的上下文切换(Context Switch)开销。
  • 多线程的管理对CPU来说又是一笔开销。
    所以,由于多线程会增加额外的资源消耗,对多线程程序而言,线程并不是越多就会越快,过多的线程返回会导致程序变慢。

本次面试答案,以及收集到的大厂必问面试题分享:

字节跳动超高难度三面java程序员面经,大厂的面试都这么变态吗?

以,由于多线程会增加额外的资源消耗,对多线程程序而言,线程并不是越多就会越快,过多的线程返回会导致程序变慢。

本次面试答案,以及收集到的大厂必问面试题分享:

[外链图片转存中…(img-IWfsXXwM-1719185660421)]

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值