TA的每日心情 | 开心 2021-3-12 23:18 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
java线程一直是一个比较容易困扰的地方,很多初学者都不是很清楚,在此,我用了几个小试验,来将其基本概念说明一下,首先把run(),start()区分开来, 看看为什么直接调用run()和用start()启动一个线程的差别
1.
package com.dragon; import java.lang.Thread; public class ThreadTest extends Thread {
public void run() {
for(int i=0;i<10;i++){
System.out.println("this is a Thread test");
}
}
public static void main(String[] args) {
try {
Thread t = new ThreadTest();
t.run();
System.out.println("main thread is over");
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
输出结果: this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
main thread is over
表明,run()和其他方法的调用没任何不同,main方法按顺序执行了它,并打印出最后一句, 退出程序.下面看看把调用改为start() 2. package com.dragon; import java.lang.Thread; public class ThreadTest extends Thread {
public void run() {
for(int i=0;i<10;i++){
System.out.println("this is a Thread test"); }
} public static void main(String[] args) {
try {
Thread t = new ThreadTest();
t.start();
System.out.println("main thread is over");
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
输出结果: main thread is over
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
这表明,start()方法重新创建了一个线程,在main方法执行结束后,由于start()方法创建的 线程没有运行结束,因此主线程未能退出,直到线程 t 也执行完毕,这里要注意,默认创建的 线程是用户线程(非守护线程),再改一下代码 3. package com.dragon; import java.lang.Thread; public class ThreadTest extends Thread {
public void run() {
for(int i=0;i<10;i++){
System.out.println("this is a Thread test"); }
} public static void main(String[] args) {
try {
Thread t = new ThreadTest();
t.setDaemon(true);
t.start();
System.out.println("main thread is over");
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
输出为: main thread is over
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test 为什么没有打印出十句呢,因为我们将 t 线程设置为了daemon(守护)线程, 程序中只有守护线程存在的时候,是可以退出的,所以只打印了七句便退出了. 再改一下代码 4. package com.dragon; import java.lang.Thread; public class ThreadTest extends Thread {
public void run() {
for(int i=0;i<100;i++){
System.out.println("this is a Thread test"); }
} public static void main(String[] args) {
try {
Thread t = new ThreadTest();
t.start();
System.out.println("main thread is over");
System.exit(0);
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
main thread is over
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test
this is a Thread test 结果可见,用户线程可以被System.exit(0)强制kill掉,所以也只打印出七句. |
|