阅读1007 返回首页    go 阿里云 go 技术社区[云栖]


JAVA线程创建底层流程

下面让我们来大概的分析下一个Java线程启动后,底层的调用细节。

环境:JDK:1.8

           glibc:2-25

           linux-kernel:2.6.0




1240
1.0-大致的执行流程

一JAVA 层面:

当我们创建一个线程并执行start()方法后这个线程才会被创建和执行。java.lang.Thread.start()方法会调用本地方法start0();

1240

二 JVM 层面:

接下来start0()方法会调用JVM_StartThread()方法:


1240

这是JVM_StartThread的具体实现,可以看到,它会创建一个JavaThread实例。

1240

我们来看看JavaThread的构造方法里边发生了什么:


1240

os::create_thread的具体实现。在这个方法中会创建一个平台相关的OSThread 实例。

1240

在os::create_thread()方法中会利用glibc库中的pthread.h中的pthread_create方法创建一个轻量级的Linux进程,这个方法执行后,线程创建控制流从JVM转到OS.

1240

三 OS层:

pthread.h 中定义pthread_create()方法。

1240

pthread_create()方法的具体实现。

1240

pthread_create 方法进入clone方法的桥梁create_thread()方法。

1240

create_thread方法的具体实现:


1240

系统调用:

1240

系统调用的处理程序:sys_clone


1240

do_fork()函数的具体实现:


1240

参考资料:①https://yq.aliyun.com/articles/67090?                                                       spm=5176.8091938.0.0.G8W8Xw

                  ②https://blog.csdn.net/u011955950/article/details/45601985

                  ③https://hllvm.group.iteye.com/group/topic/43599

最后更新:2017-04-01 16:39:46

  上一篇:go Xen Server虚拟机删除数据的恢复过程
  下一篇:go 华大基因:云计算“撬动”大基因