返回顶部
首页 > 资讯 > 后端开发 > JAVA >java并发是什么?
  • 182
分享到

java并发是什么?

java并发 2015-07-19 06:07:00 182人浏览 绘本
摘要

并发是什么?并发:是指在某个时间段内,多任务交替的执行任务。当有多个线程在操作时,把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行。 在一个时间段的线程代码运行时,其它线程处于挂起状。在并发环境下,程序的封闭性被打破,出现以

并发是什么?

并发:是指在某个时间段内,多任务交替的执行任务。当有多个线程在操作时,把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行。 在一个时间段的线程代码运行时,其它线程处于挂起状。

在并发环境下,程序的封闭性被打破,出现以下特点:

● 并发程序之间有相互制约的关系。直接制约体现为一个程序需要另一个程序的计算结果;间接体现为多个程序竞争共享资源,如处理器、缓冲区等。

● 并发程序的执行过程是断断续续的。程序需要记忆现场指令及执行点。

● 当并发数设置合理并且CPU拥有足够的处理能力时,并发会提高程序的运行效率。

在并发环境中,当一个对象可以被多个线程访问到时,会造成该对象可以被任何访问到的线程进行修改,从而出现数据不一致的情况。所以提出线程安全的概念。

并发和并行

是十分容易混淆的概念。并发指的是多个任务交替进行,而并行则是指真正意义上的“同时进行”。实际上,如果系统内只有一个CPU,使用多线程时,在真实系统环境下不能并行,只能通过切换时间片的方式交替进行,从而并发执行任务。真正的并行只能出现在拥有多个CPU的系统中。

【推荐学习:Java视频教程

为什么要用到并发?

并发编程在一定程度上离不开多核CPU的发展。随着单核CPU的研发已经不能遵循“摩尔定律”(摩尔定律是硬件发展的观测定律,另外还有基于“摩尔定律”的“反摩尔定律”,不过“反摩尔定律”是软件领域的定律,有兴趣的可以自行了解),硬件工程师们为了进一步提升计算速度,而不是再追求单独的计算单元,而是将多个计算单元整合到了一起,也就是形成了多核CPU。短短十几年的时间,家用型CPU,比如Intel i7就可以达到4核心甚至8核心。而专业服务器则通常可以达到几个独立的CPU,每一个CPU甚至拥有多达8个以上的内核。

因此,“摩尔定律”似乎在CPU核心扩展上继续得到体验。而在多核的CPU的背景下,催生了并发编程的趋势,通并发编程的形式可以将多核CPU的计算能力发挥到极致,性能得到提升。

在特殊的业务场景下先天的就适合于并发编程。比如在图像处理领域,一张1024X768像素的图片,包含达到78万6千多个像素。即时将所有的像素遍历一边都需要很长的时间,面对如此复杂的计算量就需要充分利用多核的计算的能力。

另外在开发购物平台时,为了提升响应速度,需要拆分,减库存,生成订单等等这些操作,就可以进行拆分利用多线程的技术完成。面对复杂业务模型,并行程序会比串行程序更适应业务需求,而并发编程吻合更能这种业务拆分正是因为这些优点,使得多线程技术能够得到重视,也是一名CS学习者应该掌握的:

● 充分利用多核CPU的计算能力;

● 方便进行业务拆分,提升应用性能

并发编程有哪些缺点?

频繁的上下文切换

时间片是CPU分配给各个线程的时间,因为时间非常短,所以CPU不断通过切换线程,让我们觉得多个线程是同时执行的,时间片一般是几十毫秒。

每次切换时,需要把当前的状态保存起来,以便能够进行恢复先前状态,而这个切换行为非常损耗性能,过于频繁切换反而无法发挥出多线程编程的优势。通常减少上下文切换可以采用无并发编程、 CAS算法、使用最少的线程和使用协程。

无锁并发编程:可以参照的ConcurrentHashMap锁分段的思想,不同的线程处理不同段的数据,这样在多线程竞争的条件下,可以减少上下文切换的时间。

CAS算法,利用原子下使用CAS算法来更新数据,使用了乐观锁,可以有效的减少一部分不必要的锁竞争带来的上下文切换

使用最少线程:避免创建不需要的线程,比如任务很少,但是创建了很多的线程,这样会造成大量的线程都处于等待状态

协程:在单线程里实现多任务的调度,并在单线程里维持多个任务间的切换

由于上下文切换是个相对比较耗时的操作,所以在 “Java的并发编程的艺术” 一书中有过一个实验,并发累加未必会比串行累加速度快。

线程的安全性问题

多线程编程中最难以把握的就是临界区线程安全问题,稍微不注意就会出现死锁的情况,一旦产生死锁就会造成系统功能不可用。

--结束END--

本文标题: java并发是什么?

本文链接: https://lsjlt.com/news/2211.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • java什么是并发?
    并发与并行并发:是指在某个时间段内,多任务交替的执行任务。当有多个线程在操作时,把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行。 在一个时间段的线程代码运行时,其它线程处于挂起状。并行:是指同一时刻同时处理多任务的能力。当...
    99+
    2020-11-24
    java教程 java 并发
  • java并发是什么?
    并发是什么?并发:是指在某个时间段内,多任务交替的执行任务。当有多个线程在操作时,把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行。 在一个时间段的线程代码运行时,其它线程处于挂起状。在并发环境下,程序的封闭性被打破,出现以...
    99+
    2015-07-19
    java 并发
  • java中什么是并发?
    java中什么是并发?并发:是指在某个时间段内,多任务交替的执行任务。当有多个线程在操作时,把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行。 在一个时间段的线程代码运行时,其它线程处于挂起状。简单来说,就是cpu在同一时刻...
    99+
    2016-05-09
    java教程 java 并发
  • 什么是Java并发编程
    本篇内容主要讲解“什么是Java并发编程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是Java并发编程”吧!Java多线程概述在Java中使用多线程是提高程序并发响应能力的重要手段,但同时...
    99+
    2023-06-15
  • java中并发和并行的概念是什么
    这篇文章主要介绍了java中并发和并行的概念是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Java有哪些集合类Java中的集合主要分为四类:1、List列表:有序的,可...
    99+
    2023-06-14
  • 什么是Java中的ConcurrentHashMap并发容器?
    Java中的ConcurrentHashMap是一种线程安全的并发容器,可以同时被多个线程访问和修改。它是一种高效的哈希表实现,可以在多线程环境下保证数据的一致性和可靠性。 ConcurrentHashMap的实现原理是将数据分成多个段(S...
    99+
    2023-09-19
    并发 数组 容器
  • java高并发处理机制是什么
    Java高并发处理机制是指通过使用多线程、线程池、锁、同步机制等技术来提高Java程序的并发处理能力。在Java中,可以通过以下几种...
    99+
    2023-10-11
    java
  • 什么是Java中的Git并发控制?
    Java中的Git并发控制是一种用于管理软件开发过程中多人同时修改同一代码库的机制。该机制确保在多人同时进行代码修改时,不会发生冲突和数据丢失。 Git是一种分布式版本控制系统,它允许多人同时对代码库进行修改,但这种并发修改可能会导致冲突和...
    99+
    2023-10-16
    git django 并发
  • Java并发中Synchronized的作用是什么
    本篇文章给大家分享的是有关Java并发中Synchronized的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1 引言在多线程并发编程中Synchronized一直...
    99+
    2023-05-30
    java synchronized
  • Java并发编程的三要素是什么
    本篇内容介绍了“Java并发编程的三要素是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1 原子性 1.1 原子性的定义原子性指的是一个...
    99+
    2023-06-30
  • Java并发编程学习方法是什么
    这篇文章主要讲解了“Java并发编程学习方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java并发编程学习方法是什么”吧!一:并发基础和多线程首先需要学习的就是并发的基础知识,什么...
    99+
    2023-06-02
  • mysql高并发是什么
    本篇文章为大家展示了mysql高并发是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql高并发解决方案1.利用水平分库分表,由单点分布到多点数据库中,从而...
    99+
    2024-04-02
  • java高并发的volatile与Java内存模型是什么
    这篇文章将为大家详细讲解有关java高并发的volatile与Java内存模型是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。public class Demo09 {&...
    99+
    2023-06-25
  • java并发模型中的两种锁是什么
    这篇文章主要介绍java并发模型中的两种锁是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4. 网页开发;5...
    99+
    2023-06-14
  • JVM中Java和Scala并发性基础是什么
    本篇文章给大家分享的是有关JVM中Java和Scala并发性基础是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。处理器速度数十年来一直持续快速发展,并在世纪交替之际走到了终...
    99+
    2023-06-17
  • Java并发代码设计的步骤是什么
    这篇文章主要介绍“Java并发代码设计的步骤是什么”,在日常操作中,相信很多人在Java并发代码设计的步骤是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java并发代码设计的步骤是什么”的疑惑有所帮助!...
    99+
    2023-06-17
  • java并发处理数据的方法是什么
    Java中处理并发数据的方法有以下几种:1. 使用synchronized关键字:synchronized关键字可以用于方法或代码块...
    99+
    2023-10-11
    java
  • Java并发数据结构的基石是什么
    这篇文章主要介绍了Java并发数据结构的基石是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java并发数据结构的基石是什么文章都会有所收获,下面我们一起来看看吧。线程阻塞原语Java 的线程阻塞和唤醒是通...
    99+
    2023-06-02
  • Java并发编程中并发机制的底层实现原理是什么
    今天就跟大家聊聊有关Java并发编程中并发机制的底层实现原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java中的并发机制依赖于JVM的实现和CPU指令,接下来我们深入底层...
    99+
    2023-06-19
  • java并发框架有什么用
    Java并发框架可以帮助开发者更方便地编写多线程程序,实现并发操作,提高程序的性能和效率。以下是一些Java并发框架的用途:1. E...
    99+
    2023-08-11
    java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作