Runnable更容易实现资源共享,能多个线程同时处理一个资源。

看代码

public static void main(String[] args) {  // TODO Auto-generated method stub  new MyThread().start();  new MyThread().start();  }  class MyThread extends Thread{    private int ticket = 5;    public void run(){    while(true){  System.out.println("Thread ticket = " + ticket--);    if(ticket < 0){    break;  }    }    }
}

输出结果:

Thread ticket = 5
Thread ticket = 5
Thread ticket = 4
Thread ticket = 4
Thread ticket = 3
Thread ticket = 2
Thread ticket = 3
Thread ticket = 1
Thread ticket = 2
Thread ticket = 0
Thread ticket = 1
Thread ticket = 0

这样多卖了一半的票显然不合理,用runnable试试:

public static void main(String[] args) {  // TODO Auto-generated method stub  MyThread2 m=new MyThread2();  new Thread(m).start();  new Thread(m).start();  }
class MyThread2 implements Runnable{    private int ticket = 5;    public void run(){    while(true){  System.out.println("Runnable ticket = " + ticket--);    if(ticket < 0){    break;  }    }   }
}

输出结果:

Runnable ticket = 5
Runnable ticket = 4
Runnable ticket = 3
Runnable ticket = 2
Runnable ticket = 1
Runnable ticket = 0  

这样的结果才合理。
很明显这个例子完全错误,多卖票的原因根本不是因为Runnable和Thread的区别,看调用就知道了。
使用Thread的时候是这样调用的:

new MyThread().start();
new MyThread().start(); 

而使用Runnable的时候是这样调用的:

new Thread(m).start();
new Thread(m).start();  

新建了两个MyThread对象去卖票,不卖两倍票才怪呢,而Runnable卖票的时候是同一个Runnable对象,肯定只卖一倍票,所以这个例子根本没体现Runnable和Thread的区别,再来看一个例子:

public class TicketThread extends Thread{private int ticket = 10;public void run(){for(int i =0;i<10;i++){synchronized (this){if(this.ticket>0){try {Thread.sleep(100);System.out.println(Thread.currentThread().getName()+"卖票---->"+(this.ticket--));} catch (InterruptedException e) {e.printStackTrace();}}}}}public static void main(String[] arg){TicketThread t1 = new TicketThread();new Thread(t1,"线程1").start();new Thread(t1,"线程2").start();}
}

输出结果:

线程1卖票—->10
线程1卖票—->9
线程1卖票—->8
线程2卖票—->7
线程2卖票—->6
线程1卖票—->5
线程1卖票—->4
线程2卖票—->3
线程2卖票—->2
线程1卖票—->1

(这里必须使用synchronized,否则会出现重复卖某一张票的情况,当然这点和本篇文章无关,这里不做详述。)
这样就达到了卖一倍票的结果,没毛病。这样看起来,Thread和Runnable岂不是没区别了?
找到答案很简单,点进去看Thread源码就知道了

public class Thread implements Runnable {}

可以看出,Thread实现了Runnable接口,这和上面例子中的MyThread2一样了,当我们使用

TicketThread t1 = new TicketThread();
new Thread(t1,"线程1").start();

这种写法时,就是脱裤子放屁的写法,标准写法应该是:

TicketThread t1 = new TicketThread();
t1.start();

看看源码:

public Thread(Runnable target) {init(null, target, "Thread-" + nextThreadNum(), 0);}

new Thread( new TicketThread(),"线程1").start();这种写法里面,TicketThread会被当做一个Runnable,那我还要写一个TicketThread类干嘛?所以这就是脱裤子放屁。
说了这么多,那两者的区别到底是什么?
来看看Runnable的代码:

public interface Runnable {/*** When an object implementing interface <code>Runnable</code> is used* to create a thread, starting the thread causes the object's* <code>run</code> method to be called in that separately executing* thread.* <p>* The general contract of the method <code>run</code> is that it may* take any action whatsoever.** @see     java.lang.Thread#run()*/public abstract void run();
}

结论就是:

1、效果上没区别,写法上的区别而已。
2、没有可比性,Thread实现了Runnable接口并进行了扩展,我们通常拿来进行比较只是写法上的比较,而Thread和Runnable的实质是实现的关系,不是同类东西。

无论你使用Runnable还是Thread,都有一个new Thread的过程,效果上最后都是new Thread,然后执行run方法。写法上的区别无非就是你是new Thead还是new你自定义的thread,如果你有复杂的线程操作需求,那就自定义Thread,如果只是简单的在子线程run一下任务,那就自己实现runnable,当然如果自己实现runnable的话可以多一个继承(自定义Thread必须继承Thread类,java单继承规定导致不能在继承别的了)。

作者:pkxutao
链接:https://www.jianshu.com/p/9c9a11092f26
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

Runnable和Thread比较相关推荐

  1. Android开发笔记之:Handler Runnable与Thread的区别详解

    From:http://www.jb51.net/article/37465.htm 本篇文章是对在Android中Handler Runnable与Thread的区别进行了详细的分析介绍,需要的朋友 ...

  2. Java中Runnable和Thread的区别

    2019独角兽企业重金招聘Python工程师标准>>> 在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口:Thread类是在java.la ...

  3. JAVA多线程之Runnable和Thread比较

    在我们开发的过程中常常会碰到多线程的问题,对于多线程的实现方式主要有两种:实现Runnable接口.继承Thread类.对于这两种多线程的实现方式也是有着一些差异.既然实现了多线程那必然离不开管理这些 ...

  4. Java多线程中的Runnable和Thread

    摘要: 在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口:Thread类是在java.lang包中定义的.一个类只要继承了Thread类同时覆写了本类中的r ...

  5. Runnable和Thread的区别

    1.Runnable的实现方式是实现其接口即可 2.Thread的实现方式是继承其类 3.Runnable接口支持多继承,但基本上用不到 4.Thread实现了Runnable接口并进行了扩展,而Th ...

  6. Android Handler Runnable和Thread之间的区别和联系详解

    在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口:Thread类是在java.lang包中定义的.一个类只要继承了Thread类同时覆写了本类中的run() ...

  7. Java线程之两种方法Runnable和Thread的区别

    在java中有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口: 1>Thread类是在java.lang包中定义的.一个类只要继承了Thread类同时覆写了本类中的 ...

  8. java中runnable_Java中Runnable和Thread的区别

    在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口:Thread类是在java.lang包中定义的.一个类只要继承了Thread类同时覆写了本类中的run() ...

  9. Android开发:Handler Runnable和Thread之间的区别和联系 应用--------------------看完本篇,从此一览无余!...

    http://blog.csdn.net/yanzi1225627/article/details/8582081 在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnab ...

  10. 彻底理解Runnable与Thread,真的有区别吗?

    网络上流传的最大的一个错误结论: Runnable更容易可以实现多个线程间的资源共享,而Thread不可以! 这是一个二笔的结论! Thread与Runnable的实质 Thread实现了Runnab ...

最新文章

  1. 顺便发现一bug??
  2. HttpClient学习系列 -- 学习总结
  3. C++强制类型转换:dynamic_cast、const_cast 、static_cast、reinterpret_cast
  4. 【2020牛客NOIP赛前集训营-提高组(第二场)】题解(GCD,包含,前缀,移动)
  5. Linux命令终端如何查询本机的内外网IP地址
  6. 树状数组维护区间和的模型及其拓广的简单总结
  7. 继承方式与成员属性的访问关系表
  8. 默认适应窗口_PS教程基础之cs6默认快捷键汇总及补充
  9. 解决Hadoop运行时的WARN util. NativeCodeLoader: Unable to load native-hadoop library for your platform
  10. C++类的成员函数(在类外定义成员函数、inline成员函数)
  11. 机器学习算法思想简单梳理
  12. 【前端】设置好CSS样式动态添加元素会按照样式显示
  13. 卡巴斯基一年版 送序列号
  14. 用陆地卫星 TM6数据演算 地表温度的单窗算法
  15. 修复QQ群图片不显示的方法:qq图片一直转圈圈,qq群聊天图片显示不出来
  16. HDDREG(硬盘坏道修复工具)v1.31绿色版
  17. 揭秘:顶级产品经理是如何写产品需求文档(PRD)的
  18. Python开发——8.模块
  19. 公众号裂变拉新,以婴儿辅食为诱饵,实现低成本获客!
  20. matlab getprmdflt,DFLT40A-7中文资料

热门文章

  1. 跟我学Elasticsearch(1) 什么是Elasticsearch
  2. 饥荒怎么解锁机器人_饥荒手游机器人多少天解锁_饥荒手游机器人解锁条件介绍_玩游戏网...
  3. 【安装配置RocketMQ】
  4. golang gob文件存储内容重新加载的续写问题
  5. 微软游戏服务器崩溃地平线4,极限竞速 地平线4无法正常游戏,经常在载入游戏或者游玩时游戏崩溃返回到桌面...
  6. Linux下C语言判断文件是否存在
  7. js提交form表单(Javascript)
  8. 科创人·天云数据CEO雷涛:打造正确理解数智的认知体系
  9. vue el-table 合并单元格行的方法
  10. 使用Mockito mock一个静态方法