博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java多线程学习(两)——创建一个线程
阅读量:5826 次
发布时间:2019-06-18

本文共 2404 字,大约阅读时间需要 8 分钟。

一个、java创建两个线程的方法

1、从java.lang.Thread派生一个新类线程类,其覆盖run()方法

2、实现Runnable接口。重载Runnable接口中的run()方法。

使用Thread类来创建线程和创建普通类的对象的操作是一样的,线程是Thread类或者其子类的实例对象。

二、java提供的两种创建线程的差别

java中类是单继承的,当定义一个新的线程类的时候。它仅仅能扩展一个外部类。那么当创建的线程是继承自Thread类来实现的,那么此线程类无法再扩展其它类,无法实现复杂的功能。此时,自己定义的线程类假设要扩展其它类,那么能够实现Runnable接口来实现线程类的功能,同一时候又能够扩展其它外部类。避免单继承带来的局限性。

同一时候。实现Runnable接口的方式创建的线程能够处理同一资源,从而实现资源的共享。

三、线程的创建

(1)由Thread类派生

由Thread派生出来的线程类。直接new就可以。

比如:

package com.thread.demo;public class JavaThreadDemo {	/**	 * @param args	 */	public static void main(String[] args) {		MutliThread m1 = new MutliThread("window 1");		MutliThread m2 = new MutliThread("window 2");		MutliThread m3 = new MutliThread("window 3");		m1.start();		m2.start();		m3.start();	}}class MutliThread extends Thread {	private int ticket = 100;		MutliThread(String name) {		super(name);	}		public void run() {		while(ticket > 0) {			ticket--;			System.out.println(ticket +" is saled by " + Thread.currentThread().getName());		}	}}
上面的样例中由Thread类派生出的MutliThread类,在main()方法中new了三个线程类,并调用线程类的start方法来执行线程。三个线程并发的执行。

有输出结果能够看出。

(2)实现Runnable接口

创建的类假设实现了Runnable接口,则须要使用Thread的构造方法来创建线程。

比如:

package com.thread.demo;public class JavaThreadDemo {	/**	 * @param args	 */	public static void main(String[] args) {		TestRunnable test1 = new TestRunnable("张三");		TestRunnable test2 = new TestRunnable("李四");				Thread t1 = new Thread(test1);		Thread t2 = new Thread(test2);				t1.start();		t2.start();					}}class TestRunnable implements Runnable {	private String name;		TestRunnable(String name) {		this.name = name;	}	@Override	public void run() {		for(int i = 0; i < 5; i++) {			try {				Thread.sleep(50);//模拟耗时操作				System.out.println(name + ":" + i);							} catch (InterruptedException e) {				e.printStackTrace();			}		}			}}
上面的样例中TestRunnable实现了Runnable接口,并重载了当中的run()方法,在run()方法中模拟了耗时操作。

在main()方法中,首先创建了两个TestRunnable的实例,接着调用Thread的构造方法来创建了两个线程类,最后调用线程的start()方法来执行线程。这两个线程并行执行,能够看到输出结果为

每次的输出结果都不同,由于线程的执行是不确定的。随机器和执行的状态而变化。

四、线程中须要注意的一些小问题:

1、每一个线程都有自己的名字。假设不明白指定名字。那么线程的名字由虚拟机自己分配。

主线程的名字总是main。非主线程的名字不确定,视虚拟机分配的名字而定。

全部的线程(包含主线程main)的名字都能够设置和获取它的名字。

2、获取当前线程的对象的方法:Thread.currentThread();

3、线程的运行并非按某种顺序而运行的。对于不论什么一组启动的线程来说,调度程序不能保证其运行顺序,持续时间也无法确定,上面的线程样例中。每次运行的结果都不同,正好能够说明这一点。

4、线程的run()方法执行完成,则此线程结束。一个可执行的线程或者死线程能够被又一次启动。

5、线程的调度是JVM上的一部分。在一个CPU的机器上,实际上一次仅仅能执行一个线程。一次仅仅有一个线程栈执行。JVM线程调度程序决定实际执行那个处于可执行状态的线程。

可执行状态线程被选择的顺序是不确定的。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

你可能感兴趣的文章
Zend Framework 自动加载类的实现方法
查看>>
使用Logrotate来管理系统日志
查看>>
机房管理系列之机房温湿度
查看>>
【PMP】Head First PMP 学习笔记 第七章 成本管理
查看>>
全球众多IT巨头竞相抢占云计算市场
查看>>
这台人形机器人曾登上时尚杂志封面 最近还参加了联合国大会
查看>>
mysql源码安装
查看>>
APNS MySQL Tables
查看>>
CEGUI中回车键,退格键的响应
查看>>
Double Kill!何恺明包揽全部两项最佳论文奖!清华北航上交论文活跃度名列前十...
查看>>
任正非:将打造华为统一的AI平台,2018首先在GTS部署
查看>>
货车帮CTO冯亮:利用阿里云服务,发展物流产业互联网
查看>>
iOS代码规范
查看>>
阿里云助艾尔肯实现维吾尔族音乐梦
查看>>
调查:OpenStack日渐成熟 部署率上涨44%
查看>>
具备这些特性 说明你是个优秀程序员
查看>>
富士通全面升级ETERNUS存储系统
查看>>
大数据时代的安全边界
查看>>
云栖大会首开Tech Insight首场爆棚
查看>>
如何区分块存储和文件存储?
查看>>