Java并发编程 - 基本概念

简介: 在开始我们的并发编程前,我们必须预热一下,一些基本概念必须了解。 1. 同步(Synchronous) / 异步(Asynchronous) 同步和异步都指一次方法调用。 同步:方法开始后,调用者必须等到该方法调用结束返回后,才能继续后续的操作。

在开始我们的并发编程前,我们必须预热一下,一些基本概念必须了解。

1. 同步(Synchronous) / 异步(Asynchronous)

同步和异步都指一次方法调用。

同步:方法开始后,调用者必须等到该方法调用结束返回后,才能继续后续的操作。

异步:异步方法有点像发送一个消息传递,开始后方法调用会立即返回,调用者可以马上

         进行后续的操作。

         (异步方法通常会在主线程外的另一个线程中, 不会阻碍主线程)

 

2. 并发(Concurrency) / 并行(Parallelism)

我们经常会混淆并发(Concurrency)和并行(Parallelism)。

相同点:它们都表示多个任务一起执行。

不同点:并发(Concurrency)偏重于多个任务交替执行,这些任务彼此之间可能是串行的。

            (eg: 一会儿运行任务A, 一会儿又运行任务B, 系统不会不停地在多个任务间进行切换)

           并行(Parallelism)才是真正意义上的同时执行。

场景:

如果系统只有一个CPU(单核), 如果我们使用多线程,那么是不可能并行的,因为一个CPU一次只能执行一条指令。

真实的并行只能出现在多个CPU(多核)的系统中。

 

3. 临界区

它指的是一种公共资源,该资源每次只能有一个线程使用它,一旦它被某个线程所占用,其它线程就必须等待。

 

4. 阻塞(Block) / 非阻塞(Non-Block)

阻塞和非阻塞用来形容多个线程间的相互影响。

场景:

一个线程占用了临界区资源,其它线程挂起等待,这种情况就是阻塞。

非阻塞是指所有的线程都不断向前执行,没有被挂起。

 

5. 死锁(DeadLock) / 饥饿(Starvation) / 活锁(LiveLock)

它们都属于线程的活跃性问题。

死锁是一种很严重的问题。

比如几辆车互相挡住了各自的通道,大家都不愿意让出自己的通道,导致死循环。

 

饥饿是指某个线程因为某些原因无法获得所需要的资源,导致一直无法执行。

这种情况可能是该线程的优先级太低,高优先级的线程不断抢占它需要的资源。

或者是某个线程一直占着关键资源不放,导致其它需要这个资源的线程无法执行。

 

活锁比较有趣,它指的是线程都主动将资源释放给他人使用,大家把这个资源丢来丢去,没人肯接受。

这样就导致没有一个线程可以同时拿到所有的资源而正常执行。

太谦让也不好!!^_^

 

6. 原子性(Atomicity)

原子性是指一个操作是不可中断的,该操作一旦执行,就不能被中断,即使在多线程的环境中,也不会被其他线程干扰。

 

目录
相关文章
|
1天前
|
Java API 调度
[Java并发基础]多进程编程
[Java并发基础]多进程编程
|
1天前
|
Java API 调度
[AIGC] 深入理解Java并发编程:从入门到进阶
[AIGC] 深入理解Java并发编程:从入门到进阶
|
1天前
|
前端开发 Java 测试技术
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
|
1天前
|
Dubbo Java 应用服务中间件
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
|
1天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
|
1天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
ava从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
|
1天前
|
IDE Java 开发工具
Java从入门到精通:1.3.1实践编程巩固基础知识
Java从入门到精通:1.3.1实践编程巩固基础知识
|
2天前
|
Java
Java中的并发编程:理解和应用线程池
【4月更文挑战第23天】在现代的Java应用程序中,性能和资源的有效利用已经成为了一个重要的考量因素。并发编程是提高应用程序性能的关键手段之一,而线程池则是实现高效并发的重要工具。本文将深入探讨Java中的线程池,包括其基本原理、优势、以及如何在实际开发中有效地使用线程池。我们将通过实例和代码片段,帮助读者理解线程池的概念,并学习如何在Java应用中合理地使用线程池。
|
5天前
|
IDE Java 物联网
《Java 简易速速上手小册》第1章:Java 编程基础(2024 最新版)
《Java 简易速速上手小册》第1章:Java 编程基础(2024 最新版)
13 0
|
6天前
|
存储 Java 数据库连接
java DDD 领域驱动设计思想的概念与实战
【4月更文挑战第19天】在Java开发中,领域驱动设计(Domain-Driven Design, DDD) 是一种软件设计方法论,强调以领域模型为中心的软件开发。这种方法通过丰富的领域模型来捕捉业务领域的复杂性,并通过软件满足核心业务需求。领域驱动设计不仅是一种技术策略,而且还是一种与业务专家紧密合作的思维方式
23 2