多线程及java5的线程并发库学习札记:创建线程的两种传统方式
多线程及java5的线程并发库学习笔记:创建线程的两种传统方式
第一种方式:在Thread子类覆盖的run方法中编写运行代码
第二种方式:在传递给Thread对象的Runnable对象的run方法中编写代码
总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread对象的run方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个Runnable对象,该run方法会调用Runnable对象的run方法。
问题:如果在Thread子类覆盖的run方法中编写了运行代码,也为Thread子类对象传递了一个Runnable对象,那么,线程运行时的执行代码是子类的run方法的代码?还是Runnable对象的run方法的代码?
输出结果是:run method of thread!
更多资源,请访问:bbs.naxsu.com
第一种方式:在Thread子类覆盖的run方法中编写运行代码
Thread thread1 = new Thread() { @Override public void run() { while (true) { try { Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()); System.out.println(this.getName()); } } }; thread1.start();
第二种方式:在传递给Thread对象的Runnable对象的run方法中编写代码
Thread thread2 = new Thread(new Runnable() { @Override public void run() { while (true) { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()); } } }); thread2.start();
总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread对象的run方法,如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个Runnable对象,该run方法会调用Runnable对象的run方法。
问题:如果在Thread子类覆盖的run方法中编写了运行代码,也为Thread子类对象传递了一个Runnable对象,那么,线程运行时的执行代码是子类的run方法的代码?还是Runnable对象的run方法的代码?
new Thread(new Runnable() { public void run() { System.out.println("run method of runnable!"); } }) { public void run() { System.out.println("run method of thread!"); } }.start();
输出结果是:run method of thread!
更多资源,请访问:bbs.naxsu.com