java 线程3 多线程的基本工作原理

来源:互联网 发布:cdn加速知乎 编辑:程序博客网 时间:2024/06/07 23:12

多线程的基本工作原理:

现已一个main函数中启动线程A和线程B为例,简单讲述程序工作过程;

       1、启动JVM时,对操作系统而言就是一个独立的进程,分配给独立的内存空间等等,

       2、JVM启动完成后,进入main函数,此时就是进入主线程了,守护线程如GC等也已经加载了(不会经常执行,看调度器情况),

       3、CPU继续在main函数中执行,启动线程A和线程B(不会立即执行,看调度器情况),此时用户线程共有三个,主线程,线程A,线程B,

       4、如果系统为多核处理器,则在物理上实现线程的同时执行,系统为单核处理器,就要看操作系统了,如windows的采用时间轮询方式,所有的线程轮番进入CPU执行,切换的频率主要看调度器的情况,在逻辑上可以当成三个线程同时在运行。

       5、当三个用户线程都结束了,JVM自动关闭,操作系统回收分配的内存等。

       为什么要采用多线程,主要是提高CPU的效率,程序的许多的东西都用不到CPU,比如I/O的建立等操作,如果是单线程,CPU只能干等着,如果是多线程,CPU就去做其他的事情了,不会空闲着。举个简单的实例,原始的电脑只能事情 一件一件的做,听歌只能听歌,写文档只能写文档,不能同时做;到了多线程后,就可以一边写文档一边听歌了。         以上过程都是理论上的东西,自己理解的对不对也不确定,欢迎讨论,关于代码实现、线程的状态切换和锁的问题(线程间的共享资源争夺的问题)以后会单独说明。

1 0