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

本文共 2455 字,大约阅读时间需要 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线程调度程序决定实际执行那个处于可执行状态的线程。

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

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

转载于:https://www.cnblogs.com/mfrbuaa/p/4641308.html

你可能感兴趣的文章
URL编码与解码
查看>>
日常开发时遇到的一些坑(三)
查看>>
Eclipse 安装SVN插件
查看>>
深度学习
查看>>
TCP粘包问题及解决方案
查看>>
构建之法阅读笔记02
查看>>
添加按钮
查看>>
移动端页面开发适配 rem布局原理
查看>>
Ajax中文乱码问题解决方法(服务器端用servlet)
查看>>
会计电算化常考题目一
查看>>
阿里云服务器CentOS6.9安装Mysql
查看>>
剑指offer系列6:数值的整数次方
查看>>
js 过滤敏感词
查看>>
poj2752 Seek the Name, Seek the Fame
查看>>
软件开发和软件测试,我该如何选择?(蜗牛学院)
查看>>
基本封装方法
查看>>
bcb ole拖拽功能的实现
查看>>
生活大爆炸之何为光速
查看>>
bzoj 2456: mode【瞎搞】
查看>>
[Typescript] Specify Exact Values with TypeScript’s Literal Types
查看>>