关于进程和线程的关系


这本笔记非常详尽地记录了多线程的核心概念,特别是从进程与线程的区别 深入到线程安全问题异常机制。我看你笔记里重点标注了"进程是资源分配的基本单位,线程是调度执行的基本单位",这是理解多线程的基石。

结合你的笔记内容,我帮你把核心知识点梳理并补充完整,形成一个更系统的体系,方便你复习:

一、 为什么需要多线程?(进程 vs 线程)

笔记中提到"多进程是并发编程解决方案",但"开销大",所以引入了线程。

  • 进程 :系统进行资源分配和调度的基本单位。创建/销毁进程开销大(需要切换内存空间)。
  • 线程 :进程内部的执行单元,是CPU调度和执行的基本单位。
  • 关系 :一个进程包含一个或多个线程。线程共享进程的资源(如内存、文件描述符),但有自己独立的栈空间和寄存器状态。
  • 优势:相比于多进程,线程的创建/销毁和切换开销小(轻量级),且通信更方便(直接读写共享内存)。

二、 多线程编程的核心难点(笔记重点)

你笔记右页的第一点提到了最核心的痛点,这里展开一下:

  1. 线程安全问题

    • 原因:多个线程同时操作同一个数据(共享变量),导致冲突。
    • 后果:出现数据不一致(Bug)。
    • 解决思路 :笔记中提到的 synchronized(加锁)和 volatile(保证可见性)。
      • synchronized:保证同一时刻只有一个线程能执行某段代码,解决原子性问题。
      • volatile:强制线程每次读取变量都从主内存读,解决可见性问题。
  2. 异常处理

    • 机制:单个线程如果发生了未捕获的异常,默认会导致整个进程终止。
    • 解决 :在 run()方法里使用 try-catch捕获异常。Java 后来也引入了 UncaughtExceptionHandler接口来处理这种情况。

三、 笔记中隐含的一个小问题

你在左页中间画了一个层级图,写到了"线程 -> 操作系统"。

  • 补充 :在 Java 中,我们写的 Thread类是 Java 层面的线程对象。当它调用 start()方法时,底层会通过 JNI 调用操作系统的 API(如 Linux 的 pthread_create)去创建一个真正的内核级线程。所以 Java 的线程本质上是对操作系统线程的一层封装。

四、 进程调度与线程状态

笔记右页提到"进程调度:只有一个线程的进程"。

  • 补充 :实际上,单核 CPU 下,即使是多进程,也是通过时间片轮转来调度的。而线程是 CPU 调度的最小单位
  • 线程状态(Java 中):新建 (New) -> 就绪 (Runnable) -> 运行 (Running) -> 阻塞 (Blocked/Waiting) -> 死亡 (Terminated)。
相关推荐
程序大视界15 分钟前
【C++ 从基础到项目实战】C++(六):拷贝控制——浅拷贝与深拷贝,兼谈智能指针
开发语言·c++·cpp
luck_bor17 分钟前
IO流知识点笔记
java·开发语言·笔记
程序大视界22 分钟前
【Python系列课程】Pandas(四):数据统计与排序——describe、sort_values、sample
开发语言·python·pandas
KWTXX40 分钟前
使用matlab官网的skills调用claude-待完成
开发语言·matlab
Cthy_hy1 小时前
Python算法竞赛:排列组合核心用法
开发语言·python·算法
大圣编程1 小时前
面向对象深度理解
java·开发语言·算法
爱喝水的鱼丶1 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
影寂ldy1 小时前
C# const 常量 / readonly 只读 / static readonly
java·开发语言·c#
摇滚侠1 小时前
Maven 入门+高深 体系外 jar 包导入 172
java·maven·jar