同步异步线程进程的一些思考

简介:

 同步与异步

    同步与异步在生活中随处可见。同步和异步是描述不同事件发生的依赖关系,同步是指这两个事件的发生有一定的时间顺序,异步是指这两个事件的发生是相互独立的。

    比如去食堂吃饭,你需要先去那餐具(事件A),然后去某个窗口前打饭(事件B),接着找到一个座位(事件C),最后开始享受食物(事件D)。事件ABCD有一定的依赖关系,所以它们之间需要同步。处理器中的取指、译码、执行、寄存器回写、存储器回写,各个子执行单元的动作也是同步的。在UnixShell下使用管道同时启动多个进程,这些进程之间的执行也是同步的。用VHDL编写一个简单的可复位预置计数器,如果将复位信号开始后还要在判断时钟信号,那么这个复位也是同步的。GCC编译器在运行的时候调用不同的模块(预处理、编译、优化、链接)对代码进行处理也是同步的。

    同步的事件之间需要通过信号来表示事件序列中的下一个动作可以开始了。对于上面的例子,餐具就是事件B的信号,饭就是事件C的信号等等。CPU中的取值模块取到指令之后,会译码模块发送一个信号,译码模块执行完之后再给执行模块发送信号等等。计算机中线程和进程之间的同步除了时间关系外,更侧重于合作关系,因为多个线程负责完成一个大的任务。

     异步是指事件之间是独立发生的,比如编写的带复位预置功能的计数器,如果复位信号和时钟信号没有任何关系的话,那么这么复位各种就是异步的。因为复位的操作是立即执行的,没有任何等待。在shell下启动命令的时候,在命令后面添加一个“&”符号,这个新启动的程序就会在一个新的进程中执行,和当前进程时异步运行的。一个文字应用程序可以一边排版一边打印,每排版100页,就送到打印机打印,然后接着排版。这时,处理器和打印机是异步运行的。

     再举一个例子,比如在公交车上睡过了头,发现已经过了目的地了。如果司机好心,立即停车让你下去,这就是异步的。如果司机一定要等到下一站到了,你才能下车,这就是同步的。

     在单处理器上,使用异步编程是提高应用程序响应性和效率的关键手段之一。当然,每个异步的事件都要完整的保存自己运行所需要的所有状态信息。在同步事件序列中,这些状态信息,可能会从上一个事件或者下一个事件中得到。

     计算机的所有计算都是对现实世界的模拟,不管是发动机外形优化程序还是材料分析的有限元程序,或者是关系数据库。同步异步也是对现实世界不断运行的事物事件的相互关系的一种描述。同步因为事物运动的因果关系,异步是因为事物运动的独立性。

线程和进程

     线程模型是对进程模型的改进,使用线程模型可以提高系统的吞吐量。这是因为多个线程之间共享进程的所有资源。在配置了线程模型的系统中,独立执行和调度的最小实体就不再是进程,而是线程了,进程仅仅成为容纳线程、地址空间、文件描述符、数据等等的容器了。

     线程的上下文切换速度要比进程快很多,线程本身也是一些状态信息的容器,不过和进程这个框相比,线程也就是一个杯子而已。它要记录堆栈信息,程序的执行位置,状态寄存器信息,通用寄存器信息,线程标识、互斥量、信号量等信息。

     除了上下文切换速度以外,还有一个“切换后综合征问题”。进程切换后,需要执行一个完全不同的程序,会导致TLB失效,Cache失效,还有一些其他硬件级优化的寄存器的失效。这些会导致刚切换进来的进程在开始执行的一段时间比较慢。而线程在这个问题上,所受到的影响就要小得多。

     除此之外,还有通信问题。各个线程通信的带宽比进程要大得多。因为线程共享地址空间,一个线程使用malloc开辟的内存可以给另外一个线程直接使用(传入指针)。而进程还要通过管道,队列之类的系统级通信环境。这就有点类似局域网和广域网的区别了。




本文转自hipercomer 51CTO博客,原文链接:http://blog.51cto.com/hipercomer/907955

相关文章
|
7月前
|
数据采集 存储 JSON
Python爬取知乎评论:多线程与异步爬虫的性能优化
Python爬取知乎评论:多线程与异步爬虫的性能优化
|
7月前
|
安全 算法 Java
Java 多线程:线程安全与同步控制的深度解析
本文介绍了 Java 多线程开发的关键技术,涵盖线程的创建与启动、线程安全问题及其解决方案,包括 synchronized 关键字、原子类和线程间通信机制。通过示例代码讲解了多线程编程中的常见问题与优化方法,帮助开发者提升程序性能与稳定性。
344 0
|
4月前
|
Java 测试技术 API
【JUC】(1)带你重新认识进程与线程!!让你深层次了解线程运行的睡眠与打断!!
JUC是什么?你可以说它就是研究Java方面的并发过程。本篇是JUC专栏的第一章!带你了解并行与并发、线程与程序、线程的启动与休眠、打断和等待!全是干货!快快快!
783 2
|
4月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
266 1
|
4月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
282 2
|
存储 Linux API
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
|
调度 开发者 Python
深入浅出操作系统:进程与线程的奥秘
在数字世界的底层,操作系统扮演着不可或缺的角色。它如同一位高效的管家,协调和控制着计算机硬件与软件资源。本文将拨开迷雾,深入探索操作系统中两个核心概念——进程与线程。我们将从它们的诞生谈起,逐步剖析它们的本质、区别以及如何影响我们日常使用的应用程序性能。通过简单的比喻,我们将理解这些看似抽象的概念,并学会如何在编程实践中高效利用进程与线程。准备好跟随我一起,揭开操作系统的神秘面纱,让我们的代码运行得更加流畅吧!
|
10月前
|
并行计算 Linux
Linux内核中的线程和进程实现详解
了解进程和线程如何工作,可以帮助我们更好地编写程序,充分利用多核CPU,实现并行计算,提高系统的响应速度和计算效能。记住,适当平衡进程和线程的使用,既要拥有独立空间的'兄弟',也需要在'家庭'中分享和并行的成员。对于这个世界,现在,你应该有一个全新的认识。
360 67
|
7月前
|
数据采集 监控 调度
干货分享“用 多线程 爬取数据”:单线程 + 协程的效率反超 3 倍,这才是 Python 异步的正确打开方式
在 Python 爬虫中,多线程因 GIL 和切换开销效率低下,而协程通过用户态调度实现高并发,大幅提升爬取效率。本文详解协程原理、实战对比多线程性能,并提供最佳实践,助你掌握异步爬虫核心技术。
|
8月前
|
调度 开发工具 Android开发
【HarmonyOS Next】鸿蒙应用进程和线程详解
进程的定义: 进程是系统进行资源分配的基本单位,是操作系统结构的基础。 在鸿蒙系统中,一个应用下会有三类进程:
330 0

热门文章

最新文章