【Java多线程与并发库】1.传统线程技术回顾
2016-10-17 18:10
525 查看
创建线程的两种传统方式
(1)创建Thread的子类,重写run方法
在Thread子类覆盖的run方法中编写运行代码。
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(){
@Override
public void run() {
System.out.println("Thread Runing...");
super.run();
}
}.start();
}
}
(2)给Thread类传入Runnable接口
在传递给Thread对象的Runnable对象的run方法中编写代码。
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(new Runnable(){
public void run() {
System.out.println("Thread Runing...");
}
}).start();
}
}
那我们如果同时重写Thread类和Runnable接口的run方法,上面执行的run方法到底是Runnable的还是Thread的呢?
我们还是给Thread类传入Runnable接口,但是重写Thread类和Runnable接口的run方法,
看看最后执行哪一个:
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(new Runnable(){
public void run() {
System.out.println("Thread Runing in Runnable...");
}
}){
public void run() {
System.out.println("Thread Runing in Parent Thread...");
}
}.start();
}
}
结果:
Thread Runing in Parent Thread...
总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread
对象的run()方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个
Runnable对象,该run方法会调用Runnable对象的run方法。
即是先运行的Thread对象的run方法,如果Thread对象没有重写run方法,就去运行Runnable的run方法。
两种方式的区别:
给Thread类传入Runnable接口可以实现数据共享,而且更偏向于面向对象的编程思想,所以
使用第二种比较多。
出处:http://blog.csdn.net/acmman/article/details/52639243
(1)创建Thread的子类,重写run方法
在Thread子类覆盖的run方法中编写运行代码。
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(){
@Override
public void run() {
System.out.println("Thread Runing...");
super.run();
}
}.start();
}
}
(2)给Thread类传入Runnable接口
在传递给Thread对象的Runnable对象的run方法中编写代码。
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(new Runnable(){
public void run() {
System.out.println("Thread Runing...");
}
}).start();
}
}
那我们如果同时重写Thread类和Runnable接口的run方法,上面执行的run方法到底是Runnable的还是Thread的呢?
我们还是给Thread类传入Runnable接口,但是重写Thread类和Runnable接口的run方法,
看看最后执行哪一个:
package cn.edu.hpu.test;
public class ThreadTests {
public static void main(String[] args) {
new Thread(new Runnable(){
public void run() {
System.out.println("Thread Runing in Runnable...");
}
}){
public void run() {
System.out.println("Thread Runing in Parent Thread...");
}
}.start();
}
}
结果:
Thread Runing in Parent Thread...
总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread
对象的run()方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个
Runnable对象,该run方法会调用Runnable对象的run方法。
即是先运行的Thread对象的run方法,如果Thread对象没有重写run方法,就去运行Runnable的run方法。
两种方式的区别:
给Thread类传入Runnable接口可以实现数据共享,而且更偏向于面向对象的编程思想,所以
使用第二种比较多。
出处:http://blog.csdn.net/acmman/article/details/52639243
相关文章推荐
- 【Java多线程与并发库】1.传统线程技术回顾
- Java并发库(一):传统线程技术回顾
- Java多线程与并发库高级应用-传统定时器技术回顾
- Java多线程与并发库高级应用-传统线程机制回顾
- 【Java多线程与并发库】2.传统定时器技术回顾
- 【Java多线程与并发库】01 传统线程技术
- Java多线程与并发应用-(3)-传统线程通信技术及生产者消费者模式
- 【Java多线程与并发库】2.传统定时器技术回顾
- Java多线程与并发应用-(4)-传统线程通信技术试题
- java并发-多线程之传统线程之互斥技术(Synchronized)(3)
- 01_张孝祥_Java多线程_传统线程技术回顾
- 【java并发】传统线程技术中的定时器技术
- 【java并发】传统线程技术中创建线程的两种方式
- 【java多线程与并发库】---传统java多线程<5> 线程控制
- 【Java多线程与并发库】4.传统线程同步通信技术
- 【java多线程与并发库】---传统java多线程<4> .线程状态及优先级
- Java并发库(二):传统定时器技术回顾
- 【java多线程与并发库】---传统java多线程<3> .线程分类
- 【Java多线程与并发库】4.传统线程同步通信技术
- 【java多线程与并发库】---传统java多线程<4> .线程状态及优先级