Thread与Runnable的区别(用三个窗口同时出售10张车票为例子)

运行代码
运行结果 分析
System.out.println("开始测试多线程");
class MyThread extends Thread {
private int ticket=10;
private String name;
public MyThread(String name){
this.name=name;
}
@Override
public void run() {
for (int i = 0; i < 10; i++) {
if (this.ticket > 0) {
System.out.println(name
+ "正在出售倒数第" + this.ticket-- + "张票!");
}
}
}
}
Thread thread1 = new MyThread("一号窗");
Thread thread2 = new MyThread("二号窗");
Thread thread3 = new MyThread("三号窗");
thread1.start();
thread2.start();
thread3.start();
System.out.println("结束测试多线程");
开始测试多线程
结束测试多线程
一号窗正在出售倒数第10张票!
三号窗正在出售倒数第10张票!
三号窗正在出售倒数第9张票!
三号窗正在出售倒数第8张票!
三号窗正在出售倒数第7张票!
三号窗正在出售倒数第6张票!
三号窗正在出售倒数第5张票!
三号窗正在出售倒数第4张票!
三号窗正在出售倒数第3张票!
三号窗正在出售倒数第2张票!
三号窗正在出售倒数第1张票!
二号窗正在出售倒数第10张票!
一号窗正在出售倒数第9张票!
一号窗正在出售倒数第8张票!
一号窗正在出售倒数第7张票!
一号窗正在出售倒数第6张票!
一号窗正在出售倒数第5张票!
一号窗正在出售倒数第4张票!
一号窗正在出售倒数第3张票!
一号窗正在出售倒数第2张票!
一号窗正在出售倒数第1张票!
二号窗正在出售倒数第9张票!
二号窗正在出售倒数第8张票!
二号窗正在出售倒数第7张票!
二号窗正在出售倒数第6张票!
二号窗正在出售倒数第5张票!
二号窗正在出售倒数第4张票!
二号窗正在出售倒数第3张票!
二号窗正在出售倒数第2张票!
二号窗正在出售倒数第1张票!

出现票超,会出现各窗口自行处理10张。

各个线程完全独立

System.out.println("开始测试多线程");
class MyRunnable implements Runnable {
private int ticket=10;
private String name;
public MyRunnable(String name){
this.name=name;
}
@Override
public void run() {
for (int i = 0; i < 10; i++) {
if (this.ticket > 0) {
System.out.println(name
+ "正在出售倒数第" + this.ticket-- + "张票!");
}
}
}
}
Thread thread1 = new Thread(new MyRunnable("一号窗"));
Thread thread2 = new Thread(new MyRunnable("二号窗"));
Thread thread3 = new Thread(new MyRunnable("三号窗"));
thread1.start();
thread2.start();
thread3.start();
System.out.println("结束测试多线程");

开始测试多线程
结束测试多线程
一号窗正在出售倒数第10张票!
二号窗正在出售倒数第10张票!
二号窗正在出售倒数第9张票!
二号窗正在出售倒数第8张票!
二号窗正在出售倒数第7张票!
二号窗正在出售倒数第6张票!
一号窗正在出售倒数第9张票!
二号窗正在出售倒数第5张票!
三号窗正在出售倒数第10张票!
三号窗正在出售倒数第9张票!
三号窗正在出售倒数第8张票!
三号窗正在出售倒数第7张票!
三号窗正在出售倒数第6张票!
三号窗正在出售倒数第5张票!
三号窗正在出售倒数第4张票!
三号窗正在出售倒数第3张票!
三号窗正在出售倒数第2张票!
三号窗正在出售倒数第1张票!
二号窗正在出售倒数第4张票!
二号窗正在出售倒数第3张票!
二号窗正在出售倒数第2张票!
二号窗正在出售倒数第1张票!
一号窗正在出售倒数第8张票!
一号窗正在出售倒数第7张票!
一号窗正在出售倒数第6张票!
一号窗正在出售倒数第5张票!
一号窗正在出售倒数第4张票!
一号窗正在出售倒数第3张票!
一号窗正在出售倒数第2张票!
一号窗正在出售倒数第1张票!

出现票超,会出现各窗口自行处理10张。

各个线程完全独立

System.out.println("开始测试多线程");
class MyRunnable implements Runnable {
private int ticket = 10;
@Override
public void run() {
for (int i = 0; i < 10; i++) {
if (this.ticket > 0) {
System.out.println(Thread.currentThread().getName()
+ "正在出售倒数第" + this.ticket-- + "张票!");
}
}
}
}
MyRunnable runnable=new MyRunnable();
Thread thread1 = new Thread(runnable,"一号窗");
Thread thread2 = new Thread(runnable,"二号窗");
Thread thread3 = new Thread(runnable,"三号窗");
thread1.start();
thread2.start();
thread3.start();
System.out.println("结束测试多线程");

开始测试多线程
结束测试多线程
一号窗正在出售倒数第10张票!
一号窗正在出售倒数第7张票!
一号窗正在出售倒数第6张票!
一号窗正在出售倒数第5张票!
一号窗正在出售倒数第4张票!
一号窗正在出售倒数第3张票!
一号窗正在出售倒数第2张票!
一号窗正在出售倒数第1张票!
三号窗正在出售倒数第8张票!
二号窗正在出售倒数第9张票!

票数正常,各窗口以剩下的票数出售。

线程共同使用类,但运行多次会发现

有些窗口出售同样的票,意味并发时

会出现同票出售。

总结:

采用继承Thread类方式:
 (1)优点:编写简单,如果需要访问当前线程,无需使用Thread.currentThread()方法,直接使用this,即可获得当前线程。
 (2)缺点:因为线程类已经继承了Thread类,所以不能再继承其他的父类。
采用实现Runnable接口方式:
 (1)优点:线程类只是实现了Runable接口,还可以继承其他的类。在这种方式下,可以多个线程共享同一个目标对象,所以非常适合多个相同线程来处理同一份资                源的情况。
 (2)缺点:编程稍微复杂,如果需要访问当前线程,必须使用Thread.currentThread()方法。

三、多线程之Thread与Runnable的区别的更多相关文章

  1. Java多线程之Thread、Runnable、Callable及线程池

    一.多线程 线程是指进程中的一个执行流程,一个进程中可以有多个线程.如java.exe进程中可以运行很多线程.进程是运行中的程序,是内存等资源的集合,线程是属于某个进程的,进程中的多个线程共享进程中的 ...

  2. 慕课网_细说多线程之Thread VS Runnable

    第1章 课前准备 1-1 前言 (00:49) 第2章 Thread VS Runnable 2-1 回顾线程创建的两种方式 (02:33) 继承Thread类 class MyThread exte ...

  3. 多线程编程(三)--创建线程之Thread VS Runnable

    前面写过一篇基础的创建多线程的博文: 那么本篇博文主要来对照一下这两种创建线程的差别. 继承Thread类: 还拿上篇博客的样例来说: 四个线程各自卖各自的票,说明四个线程之间没有共享,是独立的线程. ...

  4. 细说多线程之Thread与Runnable

    1:创建线程的两种方式: 继承Thread类 public class MyThread extends Thread { @Override public void run() { } } MyTh ...

  5. Android线程之Thread 、Runnable 的两个例子

    Thread例子: package fy.test; import android.app.Activity; import android.os.Bundle; import android.os. ...

  6. 细说多线程之Thread VS Runnable

    [线程创建的两种方式] [线程的生命周期] ● 就绪:创建了线程对象后,调用了线程的start(). (注意:此时线程只是进入了线程队列,等待获取CPU服务,具备了运行的条件,但并不一定已经开始运行了 ...

  7. 多线程之thread和runnable

    Runnanle方式可以避免Thread由于单继承特性带来的缺陷. Runnable代码可以被多个线程(thread实例)共享,适用于多个线程处理同一资源的情况. 线程的生命周期:创建,就绪,阻塞,运 ...

  8. Java基础-进程与线程之Thread类详解

    Java基础-进程与线程之Thread类详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.进程与线程的区别 简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程 ...

  9. iOS多线程之Thread

    多线程 • Thread 是苹果官方提供的,简单已用,可以直接操作线程对象.不过需要程序员自己管理线程的生命周期,主要是创建那部分 优缺点 面向对象,简单易用 直接操作线程对象 需要自己管理线程生命周 ...

随机推荐

  1. LZZY高级语言程序设计之169页**5.17

    import java.util.Scanner;public class MQ3 { public static void main(String[] args) { Scanner sc = ne ...

  2. java重写toString()方法

    toString()方法是Object类的方法,调用toString()会返回对象的描述信息. 1)为什么重写toString()方法呢? 如果不重写,直接调用Object类的toString()方法 ...

  3. python之commands和subprocess入门介绍(可执行shell命令的模块)

    一.commands模块 1.介绍 当我们使用Python进行编码的时候,但是又想运行一些shell命令,去创建文件夹.移动文件等等操作时,我们可以使用一些Python库去执行shell命令. com ...

  4. 《Selenium自动化测试实战:基于Python》之 Selenium IDE插件的安装与使用

    第3章  Selenium IDE插件的安装与使用 京东:https://item.jd.com/13123910.html 当当:http://product.dangdang.com/292045 ...

  5. [源码解析] 并行分布式框架 Celery 之 worker 启动 (1)

    [源码解析] 并行分布式框架 Celery 之 worker 启动 (1) 目录 [源码解析] 并行分布式框架 Celery 之 worker 启动 (1) 0x00 摘要 0x01 Celery的架 ...

  6. java例题_01 不死神兔!

    1 /*1 [程序 1 不死神兔] 2 题目:古典问题:有一对兔子,从出生后第 3 个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少? 3 程 ...

  7. AI数学基础之:确定图灵机和非确定图灵机

    目录 简介 图灵机 图灵机的缺点 等效图灵机 确定图灵机 非确定图灵机 简介 图灵机是由艾伦·麦席森·图灵在1936年描述的一种抽象机器,它是人们使用纸笔进行数学运算的过程的抽象,它肯定了计算机实现的 ...

  8. Redis解读(1):Redis安装启动及常见数据类型

    Redis 简介 Redis 是我们在互联网应用中使用最广泛的一个 NoSQL 数据库,基于 C 开发的键值对存储数据库. Redis 这个名字是 Remote Dictionary Service ...

  9. Java(279-298)【异常、线程】

    1.异常的概念&异常的体系 异常,就是不正常的意思.在生活中:医生说,你的身体某个部位有异常,该部位和正常相比有点不同,该部位的功能将 受影响.在程序中的意思就是: 异常 :指的是程序在执行过 ...

  10. Polly-故障处理和弹性应对很有一手

    前言 对于运行中的系统,可以说百分百的小伙伴会经常遇见以下问题: 网络不通,突然又好了: 服务器宕机了: 调用服务接口超时了: 调用接口报错啦: 通讯信息发送失败需要重发: 以上只是列举了一些常遇到的 ...