继承 Thread 类

class MyThread1 extends Thread{
@Override
public void run(){
System.out.println("继承 Thread ...");
}
} public class Test1 extends Thread {
public static void main(String[] args) {
new MyThread1().start();
}
}

实现 Runnable 接口

class MyThread implements Runnable{

    @Override
public void run() {
System.out.println("继承 Runnable ......");
}
}
public class Test1 {
public static void main(String[] args) {
// 创建真实对象
MyThread myThread = new MyThread();
// 创建代理对象
Thread t = new Thread(myThread);
t.start();
}
}

实现 Callable 接口

class MyThread implements Callable<String> {

    @Override
public String call() throws Exception {
return "hello world!";
}
}
public class Test1 {
public static void main(String[] args) throws ExecutionException, InterruptedException {
// 创建对象
MyThread myThread = new MyThread();
// 创建线程, 使用线程调度服务来创建, 参数表示创建线程的数量
ExecutorService t = Executors.newFixedThreadPool(1);
// 执行线程
Future<String> result = t.submit(myThread);
// 获取线程执行结果的返回值, 将会等待线程执行结束
String s = result.get();
System.out.println(s);
     // 停止线程
t.shutdownNow();
}
}

龟兔晒跑

class MyThread implements Callable<String> {
// 步数, 记录跑步的数量, 初始化为 0
private int step = 0;
// 停止线程的标识, 为 false 就跳出循环(线程体)
private boolean flag = true;
// 线程名称, 标识小兔子和乌龟
private String name; public boolean getFlag(){
return this.flag;
} public void setFlag(boolean flag) {
this.flag = flag;
} // 频率, 多少毫秒跑一步, 小兔子和老乌龟是不一样的
private long time; public MyThread(String name, long time) {
this.name = name;
this.time = time;
} @Override
public String call() throws Exception {
// 获取 flag , 如果是 true 就执行循环体
while (this.getFlag()) {
step++;
Thread.sleep(time);
}
return name + "跑了" + step + "步";
}
} public class Test1 {
public static void main(String[] args) throws ExecutionException, InterruptedException {
MyThread rabbit = new MyThread("小兔子", 500);
MyThread tortoise = new MyThread("老乌龟", 1000);
// 创建线程, 通过线程调度服务来创建, 参数表示线程数量
ExecutorService threadService = Executors.newFixedThreadPool(2);
// 执行线程
Future<String> rabbitResult = threadService.submit(rabbit);
Future<String> tortoiseResult = threadService.submit(tortoise);
// 2 秒后小兔子和乌龟停止跑步, Callable 可以抛异常
Thread.sleep(2000);
rabbit.setFlag(false);
tortoise.setFlag(false);
// 获取结果
String s = rabbitResult.get();
String s2 = tortoiseResult.get();
// 打印结果
System.out.println(s);
System.out.println(s2);
// 停止服务
threadService.shutdownNow();
}
}

停止线程

  停止线程的方法被废弃了, 如果需要停止需要手动实现, 步骤如下:

    1, 线程类中定义一个成员变量

    2, 线程体中使用该变量

    3, 对外提供方法改变标识

class MyThread2 implements Runnable{

    // 定义一个变量, 用于控制停止线程
private boolean flag = true; public boolean getFlag() {
return flag;
}
// 对外提供修改值的方法
public void setFlag(boolean flag) {
this.flag = flag;
} @Override
public void run() {
// 循环获取变量 flag 值, 如果是 true 就执行
while (this.getFlag()){
System.out.println("根本停不下来...");
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
public class Test2 { public static void main(String[] args) throws InterruptedException {
MyThread2 myThread2 = new MyThread2();
new Thread(myThread2).start(); // 两秒后停止线程
Thread.sleep(200);
myThread2.setFlag(false);
} }

Java 创建线程/停止线程的更多相关文章

  1. java并发之停止线程

    停止一个线程意味着在任务处理完任务之前停掉正在做的操作,也就是放弃当前的操作.停止一个线程可以用Thread.stop()方法,但最好不要用它.虽然它确实可以停止一个正在运行的线程,但是这个方法是不安 ...

  2. java多线程之停止线程

    /*1.让各个对象或类相互灵活交流2.两个线程都冻结了,就不能唤醒了,因为根据代码要一个线程活着才能执行唤醒操作,就像玩木游戏3.中断状态就是冻结状态4.当主线程退出的时候,里面的两个线程都处于冻结状 ...

  3. Java创建多线程和线程安全集合Vector

    public class Test { public static Vector<String> data = new Vector<String>(); public sta ...

  4. (Java多线程系列四)停止线程

    停止线程 停止线程的思路 ①使用退出标志,使线程正常退出,也就是当run()方法结束后线程终止. class Thread01 extends Thread { // volatile关键字解决线程的 ...

  5. 【Java 语言】Java 多线程 一 ( 线程启动 | 线程中断 )

    一. 线程启动 线程启动 : -- 1. 继承 Thread 运行线程 : 重写 Thread 类的 run 方法, 然后执行该线程; -- 2. 实现 Runnable 接口, 并运行线程; -- ...

  6. Thread之十:停止线程方法汇总

    在上篇文章<多线程的使用——Thread类和Runnable接口>中提到中断线程的问题.在JAVA中,曾经使用stop方法来停止线程,然而,该方法具有固有的不安全性,因而已经被抛弃(Dep ...

  7. 线程停止与volatile

    1.使用标志位停止线程 在Java中希望停止线程,可以使用设置标志位的方法,如下例所示: class SimpleTask implements Runnable{ private boolean s ...

  8. -1-5 java 多线程 概念 进程 线程区别联系 java创建线程方式 线程组 线程池概念 线程安全 同步 同步代码块 Lock锁 sleep()和wait()方法的区别 为什么wait(),notify(),notifyAll()等方法都定义在Object类中

     本文关键词: java 多线程 概念 进程 线程区别联系 java创建线程方式 线程组 线程池概念 线程安全 同步 同步代码块 Lock锁  sleep()和wait()方法的区别 为什么wait( ...

  9. Java如何停止线程?

    在Java编程中,如何停止线程? 以下示例演示了如何通过创建一个用户定义的方法run()方法和Timer类来停止线程. package com.yiibai; import java.util.Tim ...

随机推荐

  1. FAIR开源Detectron:整合全部顶尖目标检测算法

    昨天,Facebook AI 研究院(FAIR)开源了 Detectron,业内最佳水平的目标检测平台. 昨天,Facebook AI 研究院(FAIR)开源了 Detectron,业内最佳水平的目标 ...

  2. 《CLR Via C#》读书笔记:24.运行时序列化

    一.什么是运行时序列化 序列化的作用就是将对象图(特定时间点的对象连接图)转换为字节流,这样这些对象图就可以在文件系统/网络进行传输. 二.序列化/反序列化快速入门 一般来说我们通过 FCL 提供的 ...

  3. NetStandard;.netCore;FX(.netFrameWork)之间引用关系

    .NetStandard;.netCore;FX(.NetFrameWork)之间引用关系   FX引用.NetCore:不通过 NetStandard引用.NetCore:不通过   .NetCor ...

  4. SpringBoot配置Cors解决跨域请求问题

    一.同源策略简介 同源策略[same origin policy]是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源. 同源策略是浏览器安全的基石. 什么是源 源[or ...

  5. leetcode — combination-sum

    import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * Source : https://o ...

  6. Gradle nexus 解决开发机器不连网无法下载gradle插件问题

    在用gradle时常规配置如下(D:\gradle-4.9\init.d\init.gradle文件,没有这个文件时自建): ext { nexus = 'http://192.168.127.128 ...

  7. TensorFlow中的通信机制——Rendezvous(二)gRPC传输

    背景 [作者:DeepLearningStack,阿里巴巴算法工程师,开源TensorFlow Contributor] 本篇是TensorFlow通信机制系列的第二篇文章,主要梳理使用gRPC网络传 ...

  8. MySQL中间件之ProxySQL(14):ProxySQL+PXC

    返回ProxySQL系列文章:http://www.cnblogs.com/f-ck-need-u/p/7586194.html 1.ProxySQL+PXC 本文演示ProxySQL代理PXC(Pe ...

  9. Go基础系列:读取标准输入

    fmt包中提供了3类读取输入的函数: Scan家族:从标准输入os.Stdin中读取数据,包括Scan().Scanf().Scanln() SScan家族:从字符串中读取数据,包括Sscan().S ...

  10. 南大算法设计与分析课程OJ答案代码(4)--变位词、三数之和

    问题 A: 变位词 时间限制: 2 Sec  内存限制: 10 MB提交: 322  解决: 59提交 状态 算法问答 题目描述 请大家在做oj题之前,仔细阅读关于抄袭的说明http://www.bi ...