我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

本文主要对Java并发(Concurrent)相关的概念进行说明。

1.进程(Process)与线程(Thread)

  1. 进程是系统资源分配的最小单元。线程是CPU调度的最小单元。
  2. 一个 进程至少包含一个线程,可以包含多个线程。这些线程共享这个进程的资源。
  3. 每个线程都拥有独立的运行栈和程序计数器,线程切换开销小。
  4. 多进程指的是操作系统同时运行多个程序,如当前操作系统中同时运行着QQ、IE、微信等程序。
  5. 多线程指的是同一进程中同时运行多个线程,如迅雷运行时,可以开启多个线程,同时进行多个文件的下载。

    2.并行(Parallel)、并发(Concurrent)与多线程(Multithreading)

  6. 并行是指多个任务在同一时刻进行。并发是指多个任务在同一时间段内发生。
  7. 并行是物理上的同时发生,而并发是逻辑上的同时发生。
  8. 体现在程序上: 并行是指多个CPU内核在同一时刻,同时运行多个任务。并发是指单个CPU内,通过CPU调度算法,让用户感觉在同时运行多个任务。
  9. 更形象的说法: 并行是指两队人员同时使用两台咖啡机。并发是指两队人员交替使用同一台咖啡机。—-Erlang 之父 Joe Armstrong。

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

  1. 多线程即多个线程,一般只多个同时在运行的单线程。
  2. 如果是在单核CPU上,多线程肯定是并发运行的。如果是在多核CPU上,这些多线程也可能是并行运行。

    3.线程安全

    线程安全,指的是在并发的情况之下,线程的调度顺序不影响运行结果。

如不加锁控制的转账操作,在单线程运行中是安全的,但是在多线程环境中,肯定是不安全的。
这里只给出示例,具体逻辑就没不解释了。

void transferMoney(User from, User to, float amount){    to.setMoney(to.getBalance() + amount);    from.setMoney(from.getBalance() - amount);}

4.死锁

死锁是指两个或更多线程阻塞着等待其它处于死锁状态的线程所持有的锁。

例如,

  • 如果线程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面试宝典Plus》版

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

本文主要对Java并发(Concurrent)相关的概念进行说明。1.进程(Process)与线程(Thread)进程是系统资源分配的最小单元。线程是CPU调度的最小单元。一个 进程至少包含一个线程,可以包含多个线程。这些线程共享这个进程的
2023-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录