• 美团一面:为什么线程崩溃崩溃不会导致 JVM 崩溃


    网上看到一个很有意思的美团面试题:为什么线程崩溃不会导致 JVM 崩溃,这个问题我看了不少回答,但发现都没答到根上,所以决定答一答,相信大家看完肯定会有收获,本文分以下几节来探讨

    1. 线程崩溃,进程一定会崩溃吗

    2. 进程是如何崩溃的-信号机制简介

    3. 为什么在 JVM 中线程崩溃不会导致 JVM 进程崩溃

    4. openJDK 源码解析

    线程崩溃,进程一定会崩溃吗

    一般来说如果线程是因为非法访问内存引起的崩溃,那么进程肯定会崩溃,为什么系统要让进程崩溃呢,这主要是因为在进程中,各个线程的地址空间是共享的,既然是共享,那么某个线程对地址的非法访问就会导致内存的不确定性,进而可能会影响到其他线程,这种操作是危险的,操作系统会认为这很可能导致一系列严重的后果,于是干脆让整个进程崩溃

    线程共享代码段,数据段,地址空间,文件

    非法访问内存有以下几种情况,我们以 C 语言举例来看看

    1. 针对只读内存写入数据

      1. #include 
      2. #include 
      3. int main() {
      4.    char *s = "hello world";
      1. // 向只读内存写入数据,崩溃
      2.   s[1= 'H'
      3. }
    2. 访问了进程没有权限访问的地址空间(比如内核空间)

      1. #include 
      2. #include 
      3. int main() {
      4.    int *p = (int *)0xC0000fff;
      1. // 针对进程的内核空间写入数据,崩溃
      2.   *= 10
      3. }

      在 32 位虚拟地址空间中,p 指向的是内核空间,显然不具有写入权限,所以上述赋值操作会导致崩溃

    3. 访问了不存在的内存,比如

      1. #include 
      2. #include 
      3. int main() {
      4.    int *a = NULL;
      5.    *a = 1;     
      6. }

    以上错误都是访问内存时的错误,所以统一会报 Segment Fault 错误(即段错误),这些都会导致进程崩溃

    进程是如何崩溃的-信号机制简介

    那么线程崩溃后,进程是如何崩溃的呢,这背后的机制到底是怎样的,答案是信号,大家想想要干掉一个正在运行的进程是不是经常用 kill -9 pid 这样的命令,这里的 kill 其实就是给指定 pid 发送终止信号的意思,其中的 9 就是信号,其实信号有很多类型

  • 相关阅读:
    数据结构与算法复习:第七弹
    Flask-flask中的后台分页查询实现
    Python模块导入出现ModuleNotFoundError: No module named ‘***’解决方法
    网络GRE,MGRE
    Redis 持久化 - RDB 与 AOF
    Linux运维-Web服务器的配置与管理(Apache+tomcat)(没成功,最后有失败经验)
    图的基本概念
    底软驱动 | 大厂面试爱考的C++内存相关
    【深度学习】【Opencv】Python/C++调用onnx模型【基础】
    【Vue3.0移动端项目--旅游网】--项目初始化搭建
  • 原文地址:https://blog.csdn.net/m0_72885838/article/details/126450966