浏览 2221 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (1) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2012-05-17
最后修改:2012-05-17
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! 转载请注明出处:http://www.naxsu.com/duo-xian-cheng-ji-java5-di-xian-cheng-bing-fa-ku-xue-xi-bi-ji-chuang-jian-xian-cheng-di-liang-zhong-chuan-tong-fang-shi/ 更多资源,请访问:bbs.naxsu.com 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2012-05-17
java5?这和java5有啥关系?难道1.4,1.3不是这么做的?
|
|
返回顶楼 | |
发表时间:2012-05-17
wf_chn 写道 java5?这和java5有啥关系?难道1.4,1.3不是这么做的?
java5的一些新特征在后面,“多线程及java5的线程并发库学习笔记”是总标题,“创建线程的两种传统方式”才是主标题,这是个人学习笔记,有什么不对请指正 |
|
返回顶楼 | |
发表时间:2012-05-17
还没贴完?那就难怪了。。。。。
|
|
返回顶楼 | |
发表时间:2012-05-17
wf_chn 写道 还没贴完?那就难怪了。。。。。
学一点贴一点 |
|
返回顶楼 | |
发表时间:2012-05-17
创建java线程只有一种方式,那就是创建一个Thread对象,并调用了其start方法
|
|
返回顶楼 | |
发表时间:2012-05-17
hyneng 写道 wf_chn 写道 还没贴完?那就难怪了。。。。。
学一点贴一点 期待后续 |
|
返回顶楼 | |
发表时间:2012-05-17
freish 写道 创建java线程只有一种方式,那就是创建一个Thread对象,并调用了其start方法
你说的也对 不过我是这样理解的,创建一个Thread对象的两种方式 |
|
返回顶楼 | |