传统实现线程的俩种方式-笔记整理1
来源:互联网 发布:仿百度搜索源码 编辑:程序博客网 时间:2024/05/16 09:06
参考:http://www.fx114.net/qa-126-102338.aspx
1、实现线程的俩种方式 继承Thread类,实现Runnable接口
2、总结:查看Thread类的run()方法的源代码,可以看到其实这两种方式都是在调用Thread对象的run方法,
如果Thread类的run方法没有被覆盖,并且为该Thread对象设置了一个Runnable对象,该run方法会调用Runnable对象的run方法。
3、如果在Thread子类覆盖的run方法中编写了运行代码,也为Thread子类对象传递了一个Runnable对象,
那么,线程运行时的执行代码是子类的run方法的代码,还是Runnable对象的run方法的代码呢?
答:执行的是子类的run方法。应该子类覆盖了run方法,就没有去调用父类的run方法了。//使用面对对象的思维去思考
4.多线程机制会提高程序的运行效率吗?为什么会有多线程下载呢?
不会,一般来说很有可能程序运行效率还会更慢。 其实你的计算机并没有变快,只是改变了你在服务器的带宽。你去抢了别人的资源。
/*
查看Thread类run()方法源代码
private Runnable target;
@Override
public void run() {
if (target != null) {
target.run();
}
}
*/
public void test1(){
Thread thread=new Thread(){
@Override
public void run() {
while(true){
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("1:"+Thread.currentThread().getName());
//this代表当前线程对象,但这种方式不好,和另一种线程实现方式作比较会发现不可以这样
System.out.println("2:"+this.getName());
}
}
};
thread.start();
}
public void test2(){
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
while(true){
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("1:"+Thread.currentThread().getName());
//Runnable不是线程对象,此时this不代表当前线程,此时使用this就不能获取当前线程,Runnable只是提供了线程对象需要运行的代码
//这也是这种方式比较经常使用原因之一,将线程对象Thread 和 线程所要执行的任务分开,更加符合面向对象编程的思维
//System.out.println("2:"+this.getName());
}
}
});
thread.start();
}
public void test3(){/* 采用面向对象的思维方式去思考,Thread类启动时候,调用Runnable中的run方法,还是子类中的run方法 答:调用子类中的run方法,因为子类重写了父类方法,将父类的run方法覆盖掉了,不会再找runnable*/new Thread(new Runnable() {@Overridepublic void run(){while(true){try {Thread.sleep(500);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("runnable:"+Thread.currentThread().getName());}}}){public void run() {while(true){try {Thread.sleep(500);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("thread:"+Thread.currentThread().getName());}};}.start();}}
0 0
- 传统实现线程的俩种方式-笔记整理1
- 传统创建线程的两种方式
- 创建线程的两种传统方式
- 创建线程的两种传统方式
- 传统创建线程的两种方式
- 创建线程的两种传统方式
- 创建传统线程的方式
- 传统的创建线程的两种方式
- java创建线程的两种传统方式
- java多线程之创建线程的两种传统方式
- java多线程01:创建线程的两种传统方式
- 关于java传统线程的两种创建方式讲解
- 1.传统创建线程的方式
- 传统方式实现三个线程之间的通信: notify与notifyAll
- 【java并发】传统线程技术中创建线程的两种方式
- Java基础知识整理(五)- 线程同步的实现方式
- 线程-实现线程的两种方式
- ThreadLocal实现线程范围的共享变量-笔记整理4
- 腾讯课堂笔记day1+day2
- docker实用命令--未完待续
- 产品经理之互联网产品的常见商业模式
- java异常的总结
- linux下安装Nginx
- 传统实现线程的俩种方式-笔记整理1
- 部分关键字
- logistic回归
- 产品经理之竞品分析-全栈工程师熊盼
- 多边形面积交、并模板
- ubuntu14.04 Samba服务无法访问 可能没有权限 指定的网络名不再可用的问题
- 09:移动路线
- AC自动机专题——E
- day54_电力项目_webservice改造&报表导出基础