首页 > 系统相关 >进程和线程的区别

进程和线程的区别

时间:2022-10-23 16:01:16浏览次数:43  
标签:操作系统 区别 Process 程序 线程 进程 执行

进程

       进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。每个进程都有自己独立的一块内存空间,一个进程可以有多个线程,比如在Windows系统中,一个运行的xx.exe就是一个进程。 

       进程在执行时会改变状态。进程状态,部分取决于进程的当前活动。每个进程可能处于以下状态:

        •新的(new):进程正在创建。

        •运行 (running):指令正在执行。

        •等待(waiting):进程等待发生某个事件(如 I/O 完成或收到信号)。

        •就绪(ready):进程等待分配处理器。

        • 终止 (terminated):进程已经完成执行。

       这些状态名称随着操作系统的不同而有所不同,不过它们表示的状态在所有系统上都会出现。

线程

       线程(thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,并且每条线程并行执行不同的任务。同一进程中的多条线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和信号处理等等。但同一进程中的多个线程有各自的调用栈(call stack),自己的寄存器环境(register context),自己的线程本地存储(thread-local storage)。

       现代计算机运行的大多数软件都是多线程的,通过提高资源使用效率来提高系统的效率。

 

区别总

线程具有许多传统进程所具有的特征,故又称为轻型进程(Light—Weight Process)或进程元;而把传统的进程称为重型进程(Heavy—Weight Process),它相当于只有一个线程的任务。在引入了线程的操作系统中,通常一个进程都有若干个线程,至少包含一个线程。

根本区别:进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位

资源开销:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器,线程之间切换的开销小。

包含关系:如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。

内存分配:同一进程的线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的

影响关系:一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉。所以多进程要比多线程健壮。

执行过程:每个独立的进程有程序运行的入口、顺序执行序列和程序出口。但是线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制,两者均可并发执行

 

标签:操作系统,区别,Process,程序,线程,进程,执行
From: https://www.cnblogs.com/yooouk/p/16818682.html

相关文章

  • Reactor 模式线程模型
    根据Reactor的数据量和处理资源池线程数量,可以分为3钟典型实现单Reactor单线程  单Reactor多线程  主从Reactor多线程 ......
  • tvm-多线程代码生成和运行
    本文链接https://www.cnblogs.com/wanger-sjtu/p/16818492.html调用链tvm搜索算子在需要多线程运行的算子,是在codegen阶段时插入TVMBackendParallelLaunch的调用。TVMB......
  • Java线程池源码深度解析
    核心机制再分析源码之前,我们还是先回顾和熟悉下线程的核心工作机制。线程池工作原理线程池采用的是一种生产者-消费者的模型,如下图:主线程调用execute、或者submit等方法提交......
  • Java线程池submit阻塞获取结果实现原理
    前言Java线程池中提交任务运行,通常使用​​execute()​​方法就足够了。那如果想要实现在主线程中阻塞获取线程池任务运行的结果,该怎么办呢?答案是用​​submit()​​方法提......
  • 从开源项目看线程池的使用
    作为一个Java开发线程池的使用是一个绕不过去的坎,如何正确的使用线程池是每个开发面临的问题,今天我们就从开源项目中来看看那些顶级开源项目中是如何使用线程池。下面我们就......
  • 自己动手写线程池——向JDK线程池进发
    JDK线程池一瞥我们首先看一个JDK给我们提供的线程池​​ThreadPoolExecutor​​的构造函数的参数:publicThreadPoolExecutor(intcorePoolSize,......
  • Java中break ,continue ,return 的区别及作用
    break跳出总上一层循环,不再执行循环(结束当前的循环体)continue跳出本次循环,继续执行下次循环(结束正在执行的循环进入下一个循环条件)return程序返回,不再执行下面的代......
  • 驱动开发:内核监控进程与线程回调
    在前面的文章中LyShark一直在重复的实现对系统底层模块的枚举,今天我们将展开一个新的话题,内核监控,我们以监控进程线程创建为例,在Win10系统中监控进程与线程可以使用微软提供......
  • 驱动开发:内核监控进程与线程回调
    在前面的文章中LyShark一直在重复的实现对系统底层模块的枚举,今天我们将展开一个新的话题,内核监控,我们以监控进程线程创建为例,在Win10系统中监控进程与线程可以使用微软提......
  • 使用多线程优化for循环请求http接口
    packagecom.test.list;importcom.alibaba.fastjson.JSON;importcom.google.common.util.concurrent.ThreadFactoryBuilder;importjava.util.*;importjava.util.concur......