【多线程】进程与线程 并发编程 面试题总结

进程和线程

  • 进程是程序执行时的一个实例,即它是程序已经执行到何种程度的数据结构的汇集。从内核的观点看,进程的目的就是担当分配系统资源(CPU时间、内存等)的基本单位。
  • 线程是进程的一个执行流,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。
  • 一个进程由几个线程组成(拥有很多相对独立的执行流的用户程序共享应用程序的大部分数据结构)
  • 线程与同属一个进程的其他的线程共享进程所拥有的全部资源。
  • "进程------资源分配的最小单位,线程------程序执行的最小单位"。
  • 进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。

线程的出现

早期的CPU都是单核的,随着多核CPU的到来,多进程也随之出现,但在并发编程当中,多进程虽然效果也可以,但是也有缺点,进程太重量且效率不高(进程的创建与销毁,耗时,耗内存资源)。为了解决这一为题,就引入了"线程(Thread)"这一概念。线程不能独立存在,必须依附于进程,即进程包含线程。

进程是操作系统进行资源分配和调度的一个基本单位。资源包括CPU、内存、磁盘等IO设备等等。

线程与程序的区别

​ 程序:是静态的,存放在磁盘上的可执行文件

​ 进程:是动态的,是运行在内存中的程序的执行实例

​ 程序是一些指令的有序集合,而进程是程序执行的过程,进程是程序的一次执行过程。进程的状态是变化的,其包括进程的创建、调度和消亡。

​ 只要程序运行,此时就是进程,程序每运行一次,就会创建一个进程

进程和线程的关系:

  1. 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
  2. 资源分配给进程,同一进程的所有线程共享该进程的所有资源。
  3. 处理机分给线程,即真正在处理机上运行的是线程。
  4. 线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。 线程是指进程内的一个执行单元,也是进程内的可调度实体.

进程与线程的区别?(面试题)

  1. 进程是资源分配的基本单位,线程是调度执行的基本单位。
  2. 进程是包含进程的,一个进程里可以有一个或多个线程。
  3. 同一个进程的线程之间,公用同一份资源(内存+硬盘)如编程时同一个变量,省去了申请资源的开销。
  4. 进程和线程都是用来实现并发编程的,但是线程比进程更轻量。
  5. 进程与进程之间是相互独立的,不同进程的线程之间也是相互独立的,同一个进程的线程之间是相互影响的。

Java如何进行多线程编程?

线程是操作系统的概念。操作系统提供了一些API,可以操作线程。由于不同操作系统所提供的API不太相同,于是Java的JVM对这些操作系统所提供的API,统一进行了封装。使得我们在不同操作系统上用java进行多线程编程的时候,只需要使用一套API就可以了。即可跨平台。

在java中通过 Thread类 创建 Thread对象 ,就可以进一步操作 系统内部 的线程。

观察多线程情况

可以使用 IDEA 或 jconsole 观察,前提是多线程正在运行。以jconsole为例:

首先找到 jconsole ,存在于 JDK 的 bin 目录里。

通过idea的 File -> Project Settings -> SDKS 就可以找到JDK的路径了。

相关推荐
独自破碎E11 小时前
Leetcode862和至少为K的最短子数组
java·开发语言
To Be Clean Coder11 小时前
【Spring源码】getBean源码实战(二)
java·后端·spring
washingtin12 小时前
Get “https://registry-1.docker.io/v2/“: context deadline exceeded
java·开发语言
一路往蓝-Anbo12 小时前
C语言从句柄到对象 (七) —— 给对象加把锁:RTOS 环境下的并发安全
java·c语言·开发语言·stm32·单片机·嵌入式硬件·算法
利刃大大12 小时前
【SpringBoot】validation参数校验 && JWT鉴权实现 && 加密/加盐
java·spring boot·jwt·加密
小北方城市网12 小时前
第 3 课:前后端全栈联动核心 —— 接口规范 + AJAX + 跨域解决(打通前后端壁垒)
java·大数据·网络·python
千寻girling12 小时前
面试官 : “ 说一下 Map 和 WeakMap 的区别 ? ”
前端·javascript·面试
降临-max12 小时前
JavaWeb企业级开发---MySQL
java·开发语言·数据库·笔记·后端·mysql
C雨后彩虹12 小时前
二维伞的雨滴效应
java·数据结构·算法·华为·面试
oMcLin12 小时前
Ubuntu 22.04 Docker 容器启动失败:解决 Overlay2 存储驱动冲突
java·ubuntu·docker