一个、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线程调度程序决定实际执行那个处于可执行状态的线程。
可执行状态线程被选择的顺序是不确定的。
版权声明:本文博客原创文章,博客,未经同意,不得转载。