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

简介:

 同步与异步

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

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

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

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

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

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

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

线程和进程

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

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

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

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




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

相关文章
|
1月前
|
调度 开发者 Python
深入浅出操作系统:进程与线程的奥秘
在数字世界的底层,操作系统扮演着不可或缺的角色。它如同一位高效的管家,协调和控制着计算机硬件与软件资源。本文将拨开迷雾,深入探索操作系统中两个核心概念——进程与线程。我们将从它们的诞生谈起,逐步剖析它们的本质、区别以及如何影响我们日常使用的应用程序性能。通过简单的比喻,我们将理解这些看似抽象的概念,并学会如何在编程实践中高效利用进程与线程。准备好跟随我一起,揭开操作系统的神秘面纱,让我们的代码运行得更加流畅吧!
|
3月前
|
消息中间件 并行计算 安全
进程、线程、协程
【10月更文挑战第16天】进程、线程和协程是计算机程序执行的三种基本形式。进程是操作系统资源分配和调度的基本单位,具有独立的内存空间,稳定性高但资源消耗大。线程是进程内的执行单元,共享内存,轻量级且并发性好,但同步复杂。协程是用户态的轻量级调度单位,适用于高并发和IO密集型任务,资源消耗最小,但不支持多核并行。
59 1
|
1月前
|
消息中间件 Unix Linux
【C语言】进程和线程详解
在现代操作系统中,进程和线程是实现并发执行的两种主要方式。理解它们的区别和各自的应用场景对于编写高效的并发程序至关重要。
57 6
|
1月前
|
调度 开发者
深入理解:进程与线程的本质差异
在操作系统和计算机编程领域,进程和线程是两个核心概念。它们在程序执行和资源管理中扮演着至关重要的角色。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
58 5
|
29天前
|
算法 调度 开发者
深入理解操作系统:进程与线程的管理
在数字世界的复杂编织中,操作系统如同一位精明的指挥家,协调着每一个音符的奏响。本篇文章将带领读者穿越操作系统的幕后,探索进程与线程管理的奥秘。从进程的诞生到线程的舞蹈,我们将一起见证这场微观世界的华丽变奏。通过深入浅出的解释和生动的比喻,本文旨在揭示操作系统如何高效地处理多任务,确保系统的稳定性和效率。让我们一起跟随代码的步伐,走进操作系统的内心世界。
|
1月前
|
调度 开发者
核心概念解析:进程与线程的对比分析
在操作系统和计算机编程领域,进程和线程是两个基本而核心的概念。它们是程序执行和资源管理的基础,但它们之间存在显著的差异。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
56 4
|
2月前
|
并行计算 数据处理 调度
Python中的并发编程:探索多线程与多进程的奥秘####
本文深入探讨了Python中并发编程的两种主要方式——多线程与多进程,通过对比分析它们的工作原理、适用场景及性能差异,揭示了在不同应用需求下如何合理选择并发模型。文章首先简述了并发编程的基本概念,随后详细阐述了Python中多线程与多进程的实现机制,包括GIL(全局解释器锁)对多线程的影响以及多进程的独立内存空间特性。最后,通过实例演示了如何在Python项目中有效利用多线程和多进程提升程序性能。 ####
|
2月前
|
Linux 调度 C语言
深入理解操作系统:进程和线程的管理
【10月更文挑战第32天】本文旨在通过浅显易懂的语言和实际代码示例,带领读者探索操作系统中进程与线程的奥秘。我们将从基础知识出发,逐步深入到它们在操作系统中的实现和管理机制,最终通过实践加深对这一核心概念的理解。无论你是编程新手还是希望复习相关知识的资深开发者,这篇文章都将为你提供有价值的见解。
|
2月前
|
Java
java小知识—进程和线程
进程 进程是程序的一次执行过程,是系统运行的基本单位,因此进程是动态的。系统运行一个程序即是一个进程从创建,运行到消亡的过程。简单来说,一个进程就是一个执行中的程序,它在计算机中一个指令接着一个指令地执行着,同时,每个进程还占有某些系统资源如CPU时间,内存空间,文件,文件,输入输出设备的使用权等等。换句话说,当程序在执行时,将会被操作系统载入内存中。 线程 线程,与进程相似,但线程是一个比进程更小的执行单位。一个进程在其执行的过程中产生多个线程。与进程不同的是同类的多个线程共享同一块内存空间和一组系统资源,所以系统在产生一个线程,或是在各个线程之间做切换工作时,负担要比
30 1
|
2月前
深入理解操作系统:进程与线程的管理
【10月更文挑战第30天】操作系统是计算机系统的核心,它负责管理计算机硬件资源,为应用程序提供基础服务。本文将深入探讨操作系统中进程和线程的概念、区别以及它们在资源管理中的作用。通过本文的学习,读者将能够更好地理解操作系统的工作原理,并掌握进程和线程的管理技巧。
46 2