传统线程技术回顾
2013-10-31 07:31
253 查看
创建线程的两种传统方式 在Thread子类覆盖的run方法中编写运行代码 涉及一个以往知识点:能否在run方法声明上抛出InterruptedException异常,以便省略run方法内部对Thread.sleep()语句的try…catch处理? 在传递给Thread对象的Runnable对象的run方法中编写代码 总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread对象的run方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个Runnable对象,该run方法会调用Runnable对象的run方法。 问题:如果在Thread子类覆盖的run方法中编写了运行代码,也为Thread子类对象传递了一个Runnable对象,那么,线程运行时的执行代码是子类的run方法的代码?还是Runnable对象的run方法的代码? 涉及到的一个以往知识点:匿名内部类对象的构造方法如何调用父类的非默认构造方法。 定时器的应用 Timer类 TimerTask类 public class ThreadDemo { public static void main(String[] args) { Thread thread = new Thread() { public void run() { while (true) { try { Thread.sleep(5); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("1" + Thread.currentThread().getName()); System.out.println("2" + this.getName()); } } }; thread.start(); Thread thread2 = new Thread(new Runnable() { public void run() { while (true) { try { Thread.sleep(40); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("5" + Thread.currentThread().getName()); } } }); thread2.start(); new Thread( new Runnable() { public void run() { while (true) { try { Thread.sleep(40); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("56" + Thread.currentThread().getName()); } } }){ public void run() { while (true) { try { Thread.sleep(40); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("85" + Thread.currentThread().getName()); } }; }.start(); } }
相关文章推荐
- 【Java多线程与并发库】1.传统线程技术回顾
- 01_张孝祥_Java多线程_传统线程技术回顾
- 1.传统线程技术的回顾-JDK5多线程
- Java并发库(一):传统线程技术回顾
- 【张孝祥并发课程笔记】01:传统线程技术和定时器技术回顾
- 传统的线程技术回顾
- (1)传统线程技术回顾
- 传统线程技术回顾
- 传统线程技术回顾
- (1)传统线程技术回顾
- 【Java多线程与并发库】1.传统线程技术回顾
- 传统的线程技术
- 传统线程通信技术
- java并发-多线程之传统线程之互斥技术(Synchronized)(3)
- 传统定时器技术回顾
- 【java并发】传统线程技术中创建线程的两种方式
- Java 传统线程技术
- Java多线程与并发应用-(3)-传统线程通信技术及生产者消费者模式
- 【Java多线程与并发库】2.传统定时器技术回顾
- 2.传统定时器技术回顾 - Timer类 TimerTask