java多线程系列02

来源:互联网 发布:2016国家政策 云计算 编辑:程序博客网 时间:2024/06/07 08:23

java vm启动的时候会有一个java.exe的进程,该进程中至少有一个线程负责java程序的执行,且此线程运行的发吗存在于main方法中,该线程称之为主线程。
jvm启动运行时其实不是单线程的,还有负责垃圾回收机制的线程。

线程的运行状态图:

img

 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
原创粉丝点击