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
- java 线程3 多线程的基本工作原理
- 【Java多线程】线程池的工作原理详解(上)
- 【Java多线程】线程池的工作原理详解(下)
- 10065---【Java多线程】线程池的工作原理详解(上)
- Java连接池的基本工作原理
- Java连接池的基本工作原理
- Java连接池的基本工作原理
- Java连接池的基本工作原理
- Java连接池的基本工作原理
- Java连接池的基本工作原理
- java多线程—线程的基本介绍
- Java多线程--线程池的原理分析
- Java多线程线程池(3)--线程池原理
- Java线程池原理(多线程)
- Java多线程----Java 线程池的原理与实现
- Java多线程----Java 线程池的原理与实现
- 关于多线程的工作原理
- Java 多线程线程池 - 线程池原理
- 线程等待
- MATLAB常见函数(图像处理方面)
- Bullshit —— 第一期
- JS循环输出数组及数组键值
- 【c语言】scanf和getchar详解
- java 线程3 多线程的基本工作原理
- RDO1.4.7连接windows 2008出现的问题
- Playing Atari with Deep Reinforcement Learning
- mybatis批量插入
- es6 javascript的Promise对象(下)
- js
- RxJava和EventBus的区别(摘抄,仅做记录)
- vmware view创建RDS桌面
- QQ复制出来的东西,粘贴到word为什么是乱码?