美文网首页
一、进程与线程

一、进程与线程

作者: 冷火凉烟 | 来源:发表于2021-08-02 17:30 被阅读0次

一、进程和线程的定义

1. 进程

进程是执行程序的一次从创建到消亡的过程。程序本身只是指令和数据的有序集合,是一个静态概念。而进程是一个动态的概念,是系统资源分配的单位。

注:一个进程只能对应一个程序,而一个程序可以对应多个进程

2. 线程

线程是一个比进程更小的执行单位,一个进程在执行过程中可以产生多个线程,当然也至少会存在一个线程,否则进程就没有存在的意义。线程是CPU调度和执行的单位。

注:真正的多线程是指有多个CPU,即多核。很多多线程是模拟出来的,即在一个CPU的情况下,在同一个时间点,CPU只能执行一个代码,因为切换的很快,所以就有同时执行的错觉。

二、Java中的进程与线程

1. 需要注意的点

  • 线程就是独立的执行路径
  • 在程序运行时,即使自己没有创建线程,后台也会有多个线程,如主线程、GC线程
  • main() 称之为主线程,是系统的入口,用于执行整个程序
  • 在一个进程中,如果开辟了多个线程,线程的运行由调度器安排调度。调度器与操作系统密切相关,先后顺序不能人为干预
  • 对同一份资源操作时,会存在资源抢夺问题,需要加入并发控制
  • 线程会带来额外的开销,如CPU调度时间、并发控制开销
  • 每个线程在自己的工作内存交互,内存控制不当会造成数据不一致

2. 进程与线程的关系

JVM运行时数据区域

由图可以看出:

  • 一个进程可以有多个线程,多个线程共享进程的堆和方法区中的资源
  • 每个线程都有自己的程序计数器、Java虚拟机栈和本地方法栈
  • 两者最大的不同是各进程基本上都是独立的,而各线程则不一定,因为同一进程中的线程极有可能互相影响
  • 线程执行开销小,但不利于资源的管理和保护,而进程相反

三、小结

  • 进程的出现让操作系统的并发成为了可能,而线程的出现则让进程内部的并发成为了可能
  • 既然多进程可以实现并发,那么使用多线程的好处在于:
    • 通常情况下会用到共享资源,而线程间通信比进程间的通信简单
    • 线程比进程更轻量,开销更小

四、扩展

  • 上下文切换是指从一个进程(或线程)切换到另一个进程(或线程)
  • 上下文是指某一时间点 CPU 寄存器和程序计数器的内容
    • 寄存器是 CPU 内部的闪存,通常存储和访问计算过程的中间值
    • 程序计数器是一个专用的寄存器,存储正在执行的指令的位置或下一个将要被执行的指令的位置(在 Java 中的实现可参考 JVM 相关内容)
  • 上下文切换通常是计算密集型的,意味着会消耗大量时间,所以线程并不是越多越好。在实现多线程的同时减少上下文切换次数才是重点

相关文章

  • iOS_进程与线程(多进程与多线程)

    iOS_进程与线程(多进程与多线程)

  • Java 线程相关

    目录1.并行与并发2.进程与线程---- 2.1 进程---- 2.2 线程---- 2.3 进程与线程的区别--...

  • 并发编程之进程与线程

    并发编程之进程与线程 2.1 线程与进程 2.1.1 进程 2.1.2 线程 2.1.3 二者对比 2.2 并行与...

  • 进程与线程、线程池

    进程与线程的相关总结进程与线程的简单解释进程: 基本的资源分配资源线程: 最小调度单元 线程安全 线程安全是多线程...

  • OpenMP笔记

    进程与线程 进程:进程是正在运行的程序实例线程:线程是进程中实际运作单位,一个进程可以并行多个线程 进程包含如下程...

  • 详解iOS面试:进程与线程

    进程与线程 进程 = 资源管理 + 线程, 进程是资源分配单位,线程是 CPU 调度单位 以前没有线程的时候,进程...

  • Python多线程与多进程

    内容简述: 线程与进程的相关概念1、程序,进程,线程,多进程,多线程2、线程的生命周期3、并行与并发,同步与异步4...

  • OC底层原理19 - 多线程基本概念

    线程与进程 线程与进程概念 进程是指在系统中正在运行的一个应用程序。 线程是进程的基本执行单元,一个进程的所有任务...

  • GO学习笔记(18) - 并发编程(1) - 理解gorouti

    目录 进程、线程与协程 并发模模型介绍 GO并发编程介绍 进程、线程与协程 进程和线程 进程是程序在操作系统中的一...

  • 多线程与进程(面试03)

    线程与线程池 什么是线程, 提到线程就要说一下进程, 进程: 进程就是正在执行的程序,(任务管理器) 线程: 是...

网友评论

      本文标题:一、进程与线程

      本文链接:https://www.haomeiwen.com/subject/zbjjvltx.html