架构系列——架构师必备基础:并发、并行与多线程关系

简介: 架构系列——架构师必备基础:并发、并行与多线程关系

前言

架构师需要了解并发与并行的区别,为高并发的处理打下基础

一、并发

1.并发图例

上图中,每个黑体代表一个事件发生,各个事件之间的发生时间段互不相交!

这是微观上来看不是同时发生的,也就是说同一时刻只能有一个事件发生

但是一个事件结束得特别快,比如用时0.0001秒,那么从宏观上来看,可以把这几个事件当成是同时发生的。

2.并发概念

指在同一时刻只能有一条指令执行,但多个线程被快速的轮换执行,使得在宏观上具有多个线程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个线程快速交替的执行。

二、并行

1.并行图例


上图中,每个黑体代表一个事件发生,各个事件之间的发生时间段可以相交!

无论是微观还是宏观上来看都是同时发生的,也就是说同一时刻有多个事件发生。

2.并行概念

指在同一时刻,有多条指令在多个处理器上同时执行。所以无论从微观还是从宏观来看,二者都是一起执行的。

三、多线程是并发吗?

打开任务管理器中的性能:

从上图可以看到处理器的个数以及线程数。CPU就是中央处理器

下面画一个具有6个中央处理器的电脑:

处理器1运行多个线程,这是并发;6个处理器之间的线程的运行就是并行,而且同一时刻只有6个线程是并行的!(实际上一个处理器不会只处理一个线程,因为电脑本身已经运行很多线程了。)

所以,可以总结如下:

1.单处理器的情况

多线程一定是并发

2.多处理器的情况

线程个数 ≤ 处理器个数时,多线程是并行


线程个数 > 处理器个数时,多线程有并行也有并发


高并发的处理必然要首先考虑使用多个处理器,这样可以用并行缓解高并发压力,如果处理器不行的话,系统架构设计得再好也无济于事!


参考文献:


[1].CPU个数,核心数,线程数


[2].CPU,进程,线程间的执行关系


[3].线程和进程以及并行和并发的概念





相关文章
|
1天前
|
数据采集 存储 Java
高德地图爬虫实践:Java多线程并发处理策略
高德地图爬虫实践:Java多线程并发处理策略
|
8天前
|
安全 Java
深入理解 Java 多线程和并发工具类
【4月更文挑战第19天】本文探讨了Java多线程和并发工具类在实现高性能应用程序中的关键作用。通过继承`Thread`或实现`Runnable`创建线程,利用`Executors`管理线程池,以及使用`Semaphore`、`CountDownLatch`和`CyclicBarrier`进行线程同步。保证线程安全、实现线程协作和性能调优(如设置线程池大小、避免不必要同步)是重要环节。理解并恰当运用这些工具能提升程序效率和可靠性。
|
10天前
|
Java 开发者
Java中多线程并发控制的实现与优化
【4月更文挑战第17天】 在现代软件开发中,多线程编程已成为提升应用性能和响应能力的关键手段。特别是在Java语言中,由于其平台无关性和强大的运行时环境,多线程技术的应用尤为广泛。本文将深入探讨Java多线程的并发控制机制,包括基本的同步方法、死锁问题以及高级并发工具如java.util.concurrent包的使用。通过分析多线程环境下的竞态条件、资源争夺和线程协调问题,我们提出了一系列实现和优化策略,旨在帮助开发者构建更加健壮、高效的多线程应用。
7 0
|
13天前
|
Java API 调度
安卓多线程和并发处理:提高应用效率
【4月更文挑战第13天】本文探讨了安卓应用中多线程和并发处理的优化方法,包括使用Thread、AsyncTask、Loader、IntentService、JobScheduler、WorkManager以及线程池。此外,还介绍了RxJava和Kotlin协程作为异步编程工具。理解并恰当运用这些技术能提升应用效率,避免UI卡顿,确保良好用户体验。随着安卓技术发展,更高级的异步处理工具将助力开发者构建高性能应用。
|
24天前
|
机器学习/深度学习 人工智能 架构师
【架构师】AI时代架构师必备技能
【架构师】AI时代架构师必备技能
|
26天前
|
安全 Java
Java中的多线程并发控制
在Java中,多线程是实现并发执行任务的一种重要方式。然而,随着多个线程同时访问共享资源,可能会导致数据不一致和其他并发问题。因此,了解并掌握Java中的多线程并发控制机制显得尤为重要。本文将深入探讨Java的多线程并发控制,包括synchronized关键字、Lock接口、Semaphore类以及CountDownLatch类等,并通过实例代码演示其使用方法和注意事项。
12 2
|
1月前
|
算法 安全 Unix
【C++ 20 信号量 】C++ 线程同步新特性 C++ 20 std::counting_semaphore 信号量的用法 控制对共享资源的并发访问
【C++ 20 信号量 】C++ 线程同步新特性 C++ 20 std::counting_semaphore 信号量的用法 控制对共享资源的并发访问
30 0
|
1月前
|
负载均衡 Java 数据处理
【C++ 并发 线程池】轻松掌握C++线程池:从底层原理到高级应用(三)
【C++ 并发 线程池】轻松掌握C++线程池:从底层原理到高级应用
55 2
|
1月前
|
存储 监控 Java
【C++ 并发 线程池】轻松掌握C++线程池:从底层原理到高级应用(二)
【C++ 并发 线程池】轻松掌握C++线程池:从底层原理到高级应用
43 1
|
1月前
|
负载均衡 安全 Java
【C++ 并发 线程池】轻松掌握C++线程池:从底层原理到高级应用(一)
【C++ 并发 线程池】轻松掌握C++线程池:从底层原理到高级应用
57 2

热门文章

最新文章