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

java什么是并发?

java教程java并发 2020-11-24 12:11:45 701人浏览 才女
摘要

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

并发与并行

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

并行:是指同一时刻同时处理多任务的能力。当有多个线程在操作时,cpu同时处理这些线程请求的能力。

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

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

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

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

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

线程基本概念介绍

线程与进程

进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个进程包含1--n个线程。(进程是资源分配的最小单位) 。简单讲进程就是在某种程度上相互隔离的、独立运行的程序。

线程:同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换开销小。(线程是cpu调度的最小单位)

线程和进程一样分为五个阶段:创建、就绪、运行、阻塞、终止。

1.png

创建: 新创建了一个线程对象,还未调用start()方法。 如 Thread thread = new Thread();

就绪: 线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中 获取cpu 的使用权 。

运行: 运行状态(runnable)的线程获得了cpu 时间片(timeslice) ,执行程序代码。

阻塞(Blocked):线程被阻塞了,“阻塞状态”与“等待状态”的区别是:“阻塞状态”在等待着获取到一个排它,这个事件将在另外一个线程放弃这个锁的时候发生;而“等待状态”则是在等待一段时间,或者唤醒动作的发生。在程序等待进入同步区域(synchronized)的时候,线程将进入这种状态。

(一). 等待阻塞: 运行(running) 的线程执行o.wait()方法,JVM会把该线程放入等待队列(waitting queue)中。

(二). 同步阻塞: 运行(running) 的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池(lock pool)中。

(三). 其他阻塞: 运行(running) 的线程执行Thread.sleep(long ms)或t.join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入 可运行(runnable) 状态。

等待: 进入该状态的线程需要等待其他线程做出一些特定动作(通知或中断)。

阻塞:当一个线程试图获取一个内部的对象锁(非java.util.concurrent库中的锁),而该锁被其他线程持有,则该线程进入阻塞状态。

等待:当一个线程等待另一个线程通知调度器一个条件时,该线程进入等待状态。例如调用:Object.wait()、Thread.join()以及等待Lock或Condition。

超时等待(TIMED_WAITING):该状态不同于WAITING,它可以在指定的时间后自行返回。

终止(TERMINATED):表示该线程已经执行完毕。

--结束END--

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

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

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

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 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中的Git并发控制?
    Java中的Git并发控制是一种用于管理软件开发过程中多人同时修改同一代码库的机制。该机制确保在多人同时进行代码修改时,不会发生冲突和数据丢失。 Git是一种分布式版本控制系统,它允许多人同时对代码库进行修改,但这种并发修改可能会导致冲突和...
    99+
    2023-10-16
    git django 并发
  • java高并发处理机制是什么
    Java高并发处理机制是指通过使用多线程、线程池、锁、同步机制等技术来提高Java程序的并发处理能力。在Java中,可以通过以下几种...
    99+
    2023-10-11
    java
  • 什么是Java中的ConcurrentHashMap并发容器?
    Java中的ConcurrentHashMap是一种线程安全的并发容器,可以同时被多个线程访问和修改。它是一种高效的哈希表实现,可以在多线程环境下保证数据的一致性和可靠性。 ConcurrentHashMap的实现原理是将数据分成多个段(S...
    99+
    2023-09-19
    并发 数组 容器
  • Java并发中Synchronized的作用是什么
    本篇文章给大家分享的是有关Java并发中Synchronized的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1 引言在多线程并发编程中Synchronized一直...
    99+
    2023-05-30
    java synchronized
  • Java并发编程学习方法是什么
    这篇文章主要讲解了“Java并发编程学习方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java并发编程学习方法是什么”吧!一:并发基础和多线程首先需要学习的就是并发的基础知识,什么...
    99+
    2023-06-02
  • Java并发编程的三要素是什么
    本篇内容介绍了“Java并发编程的三要素是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1 原子性 1.1 原子性的定义原子性指的是一个...
    99+
    2023-06-30
  • java高并发的volatile与Java内存模型是什么
    这篇文章将为大家详细讲解有关java高并发的volatile与Java内存模型是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。public class Demo09 {&...
    99+
    2023-06-25
  • Java并发代码设计的步骤是什么
    这篇文章主要介绍“Java并发代码设计的步骤是什么”,在日常操作中,相信很多人在Java并发代码设计的步骤是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java并发代码设计的步骤是什么”的疑惑有所帮助!...
    99+
    2023-06-17
  • java并发处理数据的方法是什么
    Java中处理并发数据的方法有以下几种:1. 使用synchronized关键字:synchronized关键字可以用于方法或代码块...
    99+
    2023-10-11
    java
  • 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-02
  • Java并发编程中并发机制的底层实现原理是什么
    今天就跟大家聊聊有关Java并发编程中并发机制的底层实现原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java中的并发机制依赖于JVM的实现和CPU指令,接下来我们深入底层...
    99+
    2023-06-19
  • mysql高并发是什么
    本篇文章为大家展示了mysql高并发是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql高并发解决方案1.利用水平分库分表,由单点分布到多点数据库中,从而...
    99+
    2022-10-18
  • java并发框架有什么用
    Java并发框架可以帮助开发者更方便地编写多线程程序,实现并发操作,提高程序的性能和效率。以下是一些Java并发框架的用途:1. E...
    99+
    2023-08-11
    java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作