首页 > 系统相关 >进程与线程

进程与线程

时间:2023-11-08 20:45:29浏览次数:44  
标签:状态 线程 切换 进程 CPU 运行

一、进程

​ 我们编写的代码只是一个存储在硬盘的静态文件,通过编译后就会生成二进制可执行文件,当我们运行这个可执行文件后,它会被装载到内存中,接着 CPU 会执行程序中的每一条指令,那么这个运行中的程序,就被称为「进程」(Process)

​ 当进程要从硬盘读取数据时,CPU 不需要阻塞等待数据的返回,而是去执行另外的进程。当硬盘数据返回时,CPU 会收到个中断,于是 CPU 再继续运行这个进程。

​ 单核CPU在某一瞬间只能运行一个进程,但在一秒钟内,它可以运行多个进程,这样会让人产生并行的错觉这其实是并发。

并行和并发的区别?

并发与并行

CPU 可以从一个进程切换到另外一个进程,在切换前必须要记录当前进程中运行的状态信息,以备下次切换回来的时候可以恢复执行。

进程的状态?

​ 在一个进程的活动期间至少具备三种基本状态,即运行状态、就绪状态、阻塞状态

进程的三种基本状态

​ 各个状态的意义:

  • 运行状态(Running):该时刻进程占用 CPU;
  • 就绪状态(Ready):可运行,由于其他进程处于运行状态而暂时停止运行;
  • 阻塞状态(Blocked):该进程正在等待某一事件发生(如等待输入/输出操作的完成)而暂时停止运行,这时,即使给它CPU控制权,它也无法运行

​ 当然,进程还有另外两个基本状态:

  • 创建状态(new):进程正在被创建时的状态;
  • 结束状态(Exit):进程正在从系统中消失时的状态;

进程五种状态的变迁

​ 当有大量处于阻塞状态的进程时,这些进程会大量占用物理内存,这显然是不行的,所以,在虚拟内存管理的操作系统中,通常会把阻塞状态的进程的物理内存空间换出到硬盘,等需要再次运行的时候,再从硬盘换入到物理内存。

​ 那么,就需要一个新的状态,来描述进程没有占用实际的物理内存空间的情况,这个状态就是挂起状态。这跟阻塞状态是不一样,阻塞状态是等待某个事件的返回。

另外,挂起状态可以分为两种:

  • 阻塞挂起状态:进程在外存(硬盘)并等待某个事件的出现;
  • 就绪挂起状态:进程在外存(硬盘),但只要进入内存,即刻立刻运行;

七种状态变迁

进程的控制结构?

​ 在操作系统中,是用进程控制块process control block,PCB)数据结构来描述进程的。

PCB 是进程存在的唯一标识,这意味着一个进程的存在,必然会有一个 PCB,如果进程消失了,那么 PCB 也会随之消失。

进程的控制?

01 创建进程

​ 操作系统允许一个进程创建另一个进程,而且允许子进程继承父进程所拥有的资源。

02 终止进程

​ 进程可以有 3 种终止方式:正常结束、异常结束以及外界干预(信号 kill 掉)。

​ 当子进程被终止时,其在父进程处继承的资源应当还给父进程。而当父进程被终止时,该父进程的子进程就变为孤儿进程,会被 1 号进程收养,并由 1 号进程对它们完成状态收集工作。

03 阻塞进程

​ 当进程需要等待某一事件完成时,它可以调用阻塞语句把自己阻塞等待。而一旦被阻塞等待,它只能由另一个进程唤醒。

04 唤醒进程

​ 进程由「运行」转变为「阻塞」状态是由于进程必须等待某一事件的完成,所以处于阻塞状态的进程是绝对不可能叫醒自己的。

​ 如果某进程正在等待 I/O 事件,需由别的进程发消息给它,则只有当该进程所期待的事件出现时,才由发现者进程用唤醒语句叫醒它。

二、线程

为什么使用线程?

​ 进程之间切换消耗大、进程之间通信麻烦、共享数据麻烦。

什么是线程?

线程是进程当中的一条执行流程。

​ 同一个进程内多个线程之间可以共享代码段、数据段、打开的文件等资源,但每个线程各自都有一套独立的寄存器和栈,这样可以确保线程的控制流是相对独立的。

多线程

线程的优缺点?

​ 优点:

  • 一个进程中可以同时存在多个线程;
  • 各个线程之间可以并发执行;
  • 各个线程之间可以共享地址空间和文件等资源;

​ 缺点:

  • 当进程中的一个线程崩溃时,会导致其所属进程的所有线程崩溃(这里是针对 C/C++ 语言,Java语言中的线程奔溃不会造成进程崩溃。

进程与线程比较?

​ 线程与进程的比较如下:

  • 进程是资源(包括内存、打开的文件等)分配的单位,线程是 CPU 调度的单位;
  • 进程拥有一个完整的资源平台,而线程只独享必不可少的资源,如寄存器和栈;
  • 线程同样具有就绪、阻塞、执行三种基本状态,同样具有状态之间的转换关系;
  • 线程能减少并发执行的时间和空间开销;

对于,线程相比进程能减少开销,体现在:

  • 线程的创建时间比进程快,因为进程在创建的过程中,还需要资源管理信息,比如内存管理信息、文件管理信息,而线程在创建的过程中,不会涉及这些资源管理信息,而是共享它们;
  • 线程的终止时间比进程快,因为线程释放的资源相比进程少很多;
  • 同一个进程内的线程切换比进程切换快,因为线程具有相同的地址空间(虚拟内存共享),这意味着同一个进程的线程都具有同一个页表,那么在切换的时候不需要切换页表。而对于进程之间的切换,切换的时候要把页表给切换掉,而页表的切换过程开销是比较大的;
  • 由于同一进程的各线程间共享内存和文件资源,那么在线程之间数据传递的时候,就不需要经过内核了,这就使得线程之间的数据交互效率更高了;

标签:状态,线程,切换,进程,CPU,运行
From: https://www.cnblogs.com/dwinternet/p/17818233.html

相关文章

  • Java线程池
      ......
  • java线程:互斥锁与读写锁
    两种互斥锁机制:1、synchronized2、ReentrantLockReentrantLock是jdk5的新特性,采用ReentrantLock可以完全替代替换synchronized传统的锁机制,而且采用ReentrantLock的方式更加面向对象,也更加灵活,网上有很多关于对比两者锁方式的文章,这里就不多口舌了,大家baidu、google一下就水落石......
  • C#C++,opencv的dll中detach相关:关于调用dll后程序退出后进程仍然驻留系统列表的问题
    我在c#中调用C++的dll,内部使用了线程并detach使其独立于主线程UI运行。但后来发现程序关闭后,任务列表中的进场依然存在,即app并未实际正常退出。这个问题有很多人碰到和争论,但都没有给出明确的答案。这里提供一个理论解释和绝佳的调试排除方法:根本原因:程序退出之前,系统(或程序员......
  • C#多线程与UI响应
    一、概述在使用C#进行应用程序设计时,经常会采用多线程的方式进行一些后台任务的工作。对于不同的应用场景,使用的策略也不尽相同。1.  后台循环任务,少量UI更新:例如批量上传文件,并提供进度。这种情况使用BackgroundWorker组件是非常好的选择。2.  耗时的后......
  • WPF多UI线程
       internalclassSpashWindowManager{privatestaticSpashWindow_spashWindow;privatestaticThreadthread;publicstaticvoidShow(){thread=newThread(()=>{_spashW......
  • 多线程select并发
    目录单纯select的问题解决方法建立子线程的位置多线程的共享资源代码单纯select的问题之前的代码中,建立连接和接收数据是线性执行的关系,也就是说,建立连接时不能接收,接收时不能建立连接,所以效率仍然不够高解决方法主线程中一直执行select函数,检测文件描述符的状态,让子线程去进......
  • postgresql 后台进程及内存结构
    1.postgresql后台进程1.1主进程postmaster:/data/postgresql/postgresdir/bin/postgres主进程postmaster是整个数据库实例的总控进程,负责启动和关闭数据库实例。1.2 logger系统日志进程只有在参数logging_cllect设置为“on”时,主进程才会启动logger辅助进程。其通过postmast......
  • Linux 线程和线程同步
    1.线程的概念 【操作系统】2.进程和线程-imXuan-博客园(cnblogs.com)线程:lightweightprocess(LWP)轻量级的进程,在Linux中本质上仍然是一个进程进程:有独立的地址空间,独立PCB,可以当作只有一个线程的进程。进程是计算机资源分配的最小单位线程:有独立的PCB,共享物理地址......
  • window 查看/结束 指定进程
    CMD控制台查看所有netstat-ano回车查找指定端口号netstat-aon|findstr[端口号]查看端口号的PID进程信息tasklist|findstr[PID值]杀掉进程taskkill/T/F/PID[PID值]/TTreekill:终止指定的进程和任何由此启动的子进程/F指定要强行终止的进......
  • Java 并发多线程面试题及答案
    1、并发编程三要素?(1)原子性原子性指的是一个或者多个操作,要么全部执行并且在执行的过程中不被其他操作打断,要么就全部都不执行。(2)可见性可见性指多个线程操作一个共享变量时,其中一个线程对变量进行修改后,其他线程可以立即看到修改的结果。(3)有序性有序性,即程序的执行顺序......