java多线程系列02
来源:互联网 发布:2016国家政策 云计算 编辑:程序博客网 时间:2024/06/07 08:23
java vm启动的时候会有一个java.exe的进程,该进程中至少有一个线程负责java程序的执行,且此线程运行的发吗存在于main方法中,该线程称之为主线程。
jvm启动运行时其实不是单线程的,还有负责垃圾回收机制的线程。
线程的运行状态图:
Thread类中的start方法的解释为:(java虚拟机调用run方法)当创建的线程调用start运行时,
发现运行结果每次都不同。因为多个线程都在获取cpu的执行权,cpu执行到谁谁就执行,
某一时刻只能有一个程序在运行(多核除外)
cpu在做着快速切换以达到看上去是同时运行的效果。我们可以形象的把多线程的运行形容为在互相抢夺cpu的执行权(多线程的随机性特点--谁抢到谁执行)
thread类用于描述线程,该类就定义了一个功能,用于存储线程要运行的代码,该存储功能就是run方法。也就是说thread类中的run方法,用于存储线程要运行的代码。(创建的目的其实是为了让线程执行部分代码)
当执行如下代码时候:(注意thread本类的run方法没有执行任何结果)
package ThreadDemo1;public class demo1 {public static void main(String[] args) {Thread th1=new Thread();// 1:<span style="color:#ff6666;">创建一个线程</span>th1.start();//2<span style="color:#ff6666;">并启动这个线程 线程调用start方法时,start api的解释为:使该线程执行,java虚拟机调用其run方法</span>for(int i=0;i<10;i++){System.out.print(i+" " );} }}class ThreadDemo extends Thread{ public void run(){for(int i=0;i<60;i++){System.out.println(i);} }}
0 0
- java多线程系列02
- java多线程系列
- Java多线程系列-目录
- java多线程系列:锁
- Java多线程系列目录
- java多线程系列03
- Java多线程系列-BlockingQueue
- Java多线程系列-Executors
- Java多线程系列-ExecutorService
- Java多线程系列-ThreadFactory
- Java多线程系列-Future
- Java多线程系列-CountDownLatch
- Java多线程系列-CyclicBarrier
- Java多线程系列-Semaphore
- Java多线程系列-ThreadLocal
- Java多线程系列-ConcurrentHashMap
- Java多线程系列-CountDownLatch
- Java多线程系列目录
- VC编程经验汇总(一)
- UITableView代理cellForRowAtIndexPath不执行的相关解决方案
- 嵌套矩形问题
- 迭代算法的收敛性
- 【分享】传颂之物1+2虚伪的面具 序章【汉化硬盘版】[全CG存档&攻略+英化补丁]
- java多线程系列02
- Python3 Pickle报错 TypeError
- C++的iostream标准库介绍
- 华为机试题--3.明明的随机数
- VC编程经验汇总(二)
- 关于View和viewGroup的绘制方法mearsure(),layout(),draw()
- WPF学习——MVVM
- SQL 2016 安装
- poj 1995 快速幂【裸】