前言 仅符合本人学习情况
一、Java线程创建方式
Java中有三种线程的创建方式,分别为实现Runnable接口的run方法、继承Thread类并重写run的方法、使用FutureTask方式
class MyThread1 extends Thread
{
@Override
public void run()
{
System.out.println(Thread.currentThread().getName());
}
}
class MyThread2 implements Runnable
{
@Override
public void run()
{
System.out.println(Thread.currentThread().getName());
}
}
class MyThread3 implements Callable<String>
{
@Override
public String call() throws Exception
{
System.out.println("MyThread3:" + Thread.currentThread().getName());
return "callable"+Thread.currentThread().getName();
}
}
public class ThreadStudy {
public static void main(String[] args) throws ExecutionException, InterruptedException {
Thread t1 = new MyThread1();
Thread a1 = new Thread(new MyThread2());
t1.start();
a1.start();
Callable<String> b1 = new MyThread3();
FutureTask<String> c1 = new FutureTask<>(b1);
Thread t = new Thread(c1);
t.start();
System.out.println(c1.get());
}
}
MyThread1:Thread-0
MyThread2:Thread-1
MyThread3:Thread-2
callable : Thread-2
Process finished with exit code 0
二、线程通知与等待
Java里面所有类的父类Object有一个wait函数。
1. wait函数 当一个线程调用一个共享变量(某个类的对象)的wait()方法时,该调用线程会被阻塞挂起,直到下面几件事情之一发现才返回 :
- 其他线程调用了该 共享对象 的notify()或者notifyAll()方法;
- 其他线程调用了该 线程 的interrupt()方法,该线程抛出InterruptedException异常返回
另外需要注意的是,如果调用wait方法的线程没有事先获取该对象的监视器锁,则调用wait方法时调用线程会抛出IllegalMonitorStateException。通过执行Synchronized同步代码块使用该共享变量作为参数,即可获得监视器锁。(线程要锁定该对象之后,这里需要用到synchronized关键字,锁定哪个对象就用哪个对象来执行notify(), notifyAll(),wait(), wait(long), wait(long, int)操作,否则就会报IllegalMonitorStateException异常。) 2. wait(long timeout)函数 该函数设置一个时间,超过时间后会挂起线程会因为超时而返回,wait函数内部就是调用wait(0),如果传递一个负数,则会抛出异常IllegalArgumentException 3. notify()与 notifyAll函数 一个线程调用共享对象的notify()方法后,会唤醒一个在该共享变量上调用wait系列方法后被挂起的线程。一个共享变量上可能会有多个线程在等待,该函数是随机唤醒一个。被唤醒的线程还需要和其他线程共同竞争该共享对象的锁。notifyAll则是唤醒所有调用该共享对象的wait方法被挂起的线程。 1. wait函数
三、等待线程执行终止的join方法
|