(1) 继承java.lang.Thread类(Thread也实现了Runnable接口)

继承Thread类的方法是比较常用的一种,如果说你只是想起一条线程。没有什么其它特殊的要求,那么可以使用Thread。一般推荐Runable。Thread类实际上也是实现了Runnable接口的类。

 class ThreadDemo extends Thread {

     private int i = 1;

     ThreadDemo(String name) {
this.setName(name);
System.out.println("Creating " + name);
} @Override
public void run() {
System.out.println("Running " + this.getName());
try {
for (; i <= 5; i++) {
System.out.println("Thread: " + this.getName() + " [" + i + "]");
// Thread.sleep()方法调用目的是不让当前线程独自霸占该进程所获取的CPU资源,以留出一定时间给其他线程执行的机会。
Thread.sleep((int) (Math.random() * 100));
}
} catch (InterruptedException e) {
System.out.println("Thread " + this.getName() + " interrupted.");
}
System.out.println("Thread " + this.getName() + " exiting.");
} @Override
public void start() {
System.out.println("Starting " + this.getName());
super.start();
}
} // 程序启动运行main时候,java虚拟机启动一个进程,主线程main在main()调用时候被创建。
// 随着调用ThreadDemo的两个对象的start方法,另外两个线程也启动了,这样,整个应用就在多线程下运行。
public class TestThread {
public static void main(String args[]) {
ThreadDemo t1 = new ThreadDemo("Thread-1");
// start()方法的调用后并不是立即执行多线程代码,而是使得该线程变为可运行态(Runnable),什么时候运行是由操作系统决定的。
t1.start();
ThreadDemo t2 = new ThreadDemo("Thread-2");
t2.start();
}
}

(2) 直接实现java.lang.Runnable接口

通过实现Runnable接口,使得该类有了多线程类的特征。run()方法是多线程程序的一个约定。所有的多线程代码都在run方法里面。

在启动的多线程的时候,需要先通过Thread类的构造方法Thread(Runnable target) 构造出对象,然后调用Thread对象的start()方法来运行多线程代码。

如果一个类继承Thread,则不适合资源共享。但是如果实现了Runable接口的话,则很容易的实现资源共享。

 class RunnableDemo implements Runnable {

     private int i = 1;

     RunnableDemo() {
System.out.println("Creating" + Thread.currentThread().getName());
} @Override
public void run() {
System.out.println("Running " + Thread.currentThread().getName());
try {
for (; i <= 5; i++) {
System.out.println("Thread: " + Thread.currentThread().getName() + " [" + i + "]");
Thread.sleep((int) (Math.random() * 100));
}
} catch (InterruptedException e) {
System.out.println("Thread " + Thread.currentThread().getName() + " interrupted.");
}
System.out.println("Thread " + Thread.currentThread().getName() + " exiting.");
}
} public class TestRunnable { public static void main(String args[]) {
Runnable r1 = new RunnableDemo();
Thread t1 = new Thread(r1);
t1.setName("Thread-1");
t1.start(); Runnable r2 = new RunnableDemo();
Thread t2 = new Thread(r2);
t2.setName("Thread-2");
t2.start();
}
}
package com.mycloud.demo.thread;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future; class CallableDemo implements Callable<String> { private int i = 1; CallableDemo() {
System.out.println("Creating " + Thread.currentThread().getName());
} @Override
public String call() {
System.out.println("Running " + Thread.currentThread().getName());
try {
for (; i <= 5; i++) {
System.out.println("Thread: " + Thread.currentThread().getName() + " [" + i + "]");
Thread.sleep((int) (Math.random() * 100));
}
} catch (InterruptedException e) {
System.out.println("Thread " + Thread.currentThread().getName() + " interrupted.");
return "failed";
}
System.out.println("Thread " + Thread.currentThread().getName() + " exiting.");
return "success";
}
} public class TestCallable { public static void main(String args[]) { ExecutorService ex = Executors.newFixedThreadPool(5);
List<Future<String>> futures = new ArrayList<>();
futures.add(ex.submit(new CallableDemo()));
futures.add(ex.submit(new CallableDemo())); try {
for (Future<String> future : futures) {
System.out.println(future.get());
}
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
} finally {
ex.shutdown();
}
}
}

Java多线程(1):3种常用的实现多线程类的方法的更多相关文章

  1. 用python介绍4种常用的单链表翻转的方法

    这里给出了4种4种常用的单链表翻转的方法,分别是: 开辟辅助数组,新建表头反转,就地反转,递归反转 # -*- coding: utf-8 -*- ''' 链表逆序 ''' class ListNod ...

  2. 23种常用设计模式的UML类图

    23种常用设计模式的UML类图 本文UML类图参考<Head First 设计模式>(源码)与<设计模式:可复用面向对象软件的基础>(源码)两书中介绍的设计模式与UML图. 整 ...

  3. 转载:23种常用设计模式的UML类图

    转载至:https://www.cnblogs.com/zytrue/p/8484806.html 23种常用设计模式的UML类图 本文UML类图参考<Head First 设计模式>(源 ...

  4. Java多线程(二)——常用的实现多线程的两种方式

    一.继承Thread类创建线程类 Java使用Thread类代表线程,所有的线程对象都必须是Thread类或其子类的实例.每个线程的作用是完成一定的任务,实际上就是执行一段程序流即一段顺序执行的代码. ...

  5. java单例模式(两种常用模式)

    单例模式是java中常见的设计模式 特点: 单例类只能有一个实例 单例类必须自己创建自己的唯一实例 单例类必须给所有的其他对象提供这一实例 单例模式是某个类只能有一个实例而且自动实例化并且向整个系统提 ...

  6. Javascript中两种最通用的定义类的方法

    在Javascript中,一切都是对象,包括函数.在Javascript中并没有真正的类,不能像C#,PHP等语言中用 class xxx来定义.但Javascript中提供了一种折中的方案:把对象定 ...

  7. java开发过程中几种常用算法

    排序算法 排序算法中包括:简单排序.高级排序 简单排序 简单排序常用的有:冒泡排序.选择排序.插入排序 冒泡排序代码如下: private static void bubbleSrot(int[] a ...

  8. 用 Java 实现的八种常用排序算法

    八种排序算法可以按照如图分类 交换排序 所谓交换,就是序列中任意两个元素进行比较,根据比较结果来交换各自在序列中的位置,以此达到排序的目的. 1. 冒泡排序 冒泡排序是一种简单的交换排序算法,以升序排 ...

  9. Java中的几种常用循环

     循环的条件 反复执行一段相同或相似的代码 一     for循环        先判断,再执行   代码示例为 ① for (int i = 0; i < args.length; i++) ...

随机推荐

  1. LoadRunner(1)

    性能测试:HP LoadRunner11 一.初步概念: 1.功能测试:测试产品的功能是否满足功能需求. 如:ATM取款(在线取款)是否成功或转账操作是否成功 -- 一个用户 2.性能测试:测试产品的 ...

  2. 【未知来源】Randomized Binary Search Tree

    题意 求 \(n\) 个点的 Treap 深度为 \(h=0,1,2,\cdots,n\) 的概率. Treap 是一个随机二叉树,每个节点有权值和优先级,权值和优先级都是 \([0,1]\) 中的随 ...

  3. 数据驱动——ddt

    1: pip3 install ddt 2: @ddt 装饰 @data((2,3),(4,5)) 支持列表,元祖,字典 @unpack 解压数据   1 import unittest 2 from ...

  4. java 实现链表

    public class MyList { Entry head; class Entry { Object data; Entry next; public Entry(Object data) { ...

  5. 帝都之行9day:正式上班第一天

    今天是我正式上班的第一天. 面了两天,三家公司,然后周五就去办入职了,我是不是太随便了点,捂脸. 不管怎么说,又要开始上班啦,CRUD的日子又要开始了…… 加油吧!

  6. Python之日期操作及转换详解

    # 导入datetime模块,用以操作时间 import datetime # 导入time模块 import time # 获取当前时间 格式: 年-月-日 时:分:秒 . 毫秒 nowTime = ...

  7. springboot2.x下actuator模块

    一.简介    spring-boot-starter-actuator模块是一个spring提供的监控模块.我们在开运行发过程中,需要实时和定时监控服务的各项状态和可用性.Spring Boot的s ...

  8. C语言构建小型Web服务器

    #include <stdio.h> #include <sys/socket.h> #include <stdlib.h> #include <string ...

  9. tomcat下载与安装

    https://www.cnblogs.com/limn/p/9358657.html

  10. hdu 5533 正n边形判断 精度处理

    Dancing Stars on Me Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...