(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种常用的实现多线程类的方法的更多相关文章
-
用python介绍4种常用的单链表翻转的方法
这里给出了4种4种常用的单链表翻转的方法,分别是: 开辟辅助数组,新建表头反转,就地反转,递归反转 # -*- coding: utf-8 -*- ''' 链表逆序 ''' class ListNod ...
-
23种常用设计模式的UML类图
23种常用设计模式的UML类图 本文UML类图参考<Head First 设计模式>(源码)与<设计模式:可复用面向对象软件的基础>(源码)两书中介绍的设计模式与UML图. 整 ...
-
Java多线程(二)——常用的实现多线程的两种方式
一.继承Thread类创建线程类 Java使用Thread类代表线程,所有的线程对象都必须是Thread类或其子类的实例.每个线程的作用是完成一定的任务,实际上就是执行一段程序流即一段顺序执行的代码. ...
-
java单例模式(两种常用模式)
单例模式是java中常见的设计模式 特点: 单例类只能有一个实例 单例类必须自己创建自己的唯一实例 单例类必须给所有的其他对象提供这一实例 单例模式是某个类只能有一个实例而且自动实例化并且向整个系统提 ...
-
Javascript中两种最通用的定义类的方法
在Javascript中,一切都是对象,包括函数.在Javascript中并没有真正的类,不能像C#,PHP等语言中用 class xxx来定义.但Javascript中提供了一种折中的方案:把对象定 ...
-
java开发过程中几种常用算法
排序算法 排序算法中包括:简单排序.高级排序 简单排序 简单排序常用的有:冒泡排序.选择排序.插入排序 冒泡排序代码如下: private static void bubbleSrot(int[] a ...
-
用 Java 实现的八种常用排序算法
八种排序算法可以按照如图分类 交换排序 所谓交换,就是序列中任意两个元素进行比较,根据比较结果来交换各自在序列中的位置,以此达到排序的目的. 1. 冒泡排序 冒泡排序是一种简单的交换排序算法,以升序排 ...
-
Java中的几种常用循环
循环的条件 反复执行一段相同或相似的代码 一 for循环 先判断,再执行 代码示例为 ① for (int i = 0; i < args.length; i++) ...
-
FutureTask的用法及两种常用的使用场景 + FutureTask的方法执行示意图
from: https://blog.csdn.net/linchunquan/article/details/22382487 FutureTask可用于异步获取执行结果或取消执行任务的场景.通过 ...
随机推荐
-
单机最大tcp连接数
from:http://www.cnblogs.com/mydomain/archive/2013/05/27/3100835.html 单机最大tcp连接数 网络编程 在tcp应用中,server事 ...
-
意外发现,VC断点可加在构造函数的左括号上
CTestApp::CTestApp() { // 断点加在这里,然后可单步进入CTestApp的父类CWinApp的构造函数进行调试! ; } 并且在CWinApp的构造函数的左括号上,可进一步进入 ...
-
AIDL实例
转载声明:原文转自:http://www.cnblogs.com/xiezie/p/5658372.html 什么是AIDL Android系统中的进程之间不能共享内存,因此,需要提供一些机制在不同进 ...
-
Android-它们的定义Dialog
Android-它们的定义Dialog 2014年4月27日 星期天 天气晴朗 心情平静 本篇博文来分享一个也是开发中常常须要用到的功能-自己定义对话框,这里我用到了Android中的图形资源shap ...
-
查看实时公网ip
icanhazip.com 使您在任何地方知道你的公网IP地址 icanhazip.com 使你在任何地方知道你的公网IP地址 icanhazip.com 使你在任何地方知道你的公网IP地址 ican ...
-
javabean解决jsp中中文乱码问题
问题描述:useBean行为定义了Java Bean对象(Person类包括姓名[string],年龄[int]),使用html页面向JSP页面提交数据,JSP页面中使用Java Bean行为来处理提 ...
-
Python之路番外(第二篇):PYTHON基本数据类型和小知识点
一.基础小知识点 1.如果一行代码过长,可以用续行符 \换行书写 例子 if (signal == "red") and \ (car == "moving") ...
-
Ubuntu修改apt-get源
1.背景 服务器上安装了最新的Ubuntu Server 17.04,代号为zesty.使用apt-get命令安装软件时,有时候速度比较慢,有时候会失败.因此考虑用国内的镜像源更换下apt-get的默 ...
-
【Python】print array时array中间是省略号没有输出全部的解决方法
在开头加入: import numpy as np np.set_printoptions(threshold=np.inf) 大量元素情况 可以采用set_printoptions(threshol ...
-
STA分析(三) cmos模型
CMOS集成电路的基本结构是以P型材料作为衬底(p-substrate),直接生成NMOS, 同时增加N肼(n-well),在其上制造PMOS. 增加两个bulk(P+,N+)防止非MOS管内的PN结 ...