1 线程的实现
java5以前,有如下两种:
有两种实现方法,分别使用new Thread()
和newThread(runnable)
形式,第一种直接调用thread的run
方法,所以,我们往往使用Thread
子类,即new SubThread()
。第二种调用runnable
的run
方法。分别是继承Thread类与实现Runnable接口
1.1 基础Thread类
newThread(){}.start()
;这表示调用Thread
子类对象的run
方法,newThread(){}
表示一个Thread
的匿名子类的实例对象,子类加上run
方法后的代码如下:
new Thread(){
public void run(){
//代码
}
}.start();
1.2 实现Runnable类
new Thread(newRunnable(){}).start()
;这表示调用Thread
对象接受的Runnable
对象的run
方法,newRunnable(){}
表示一个Runnable
的匿名子类的实例对象,runnable
的子类加上run
方法后的代码如下:
new Thread(newRunnable(){
public void run(){
//代码
}
}
).start();
1.3 线程池写法
从java5
开始,还有如下一些线程池创建多线程的方式:
ExecutorService pool= Executors.newFixedThreadPool(3)
for(inti=0;i<10;i++){
pool.execute(new Runable(){public voidrun(){}});
}
//或者另外一种写法
Executors.newCachedThreadPool().execute(newRunable(){public void run(){}});
//或者又有另一种写法
Executors.newSingleThreadExecutor().execute(newRunable(){public void run(){}});
2 stop和suspend方法
用synchronized
关键字修饰同步方法
反对使用stop()
,是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。
suspend()
方法容易发生死锁。调用suspend()
的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,除非被"挂起"
的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源
,就会造成死锁。所以不应该使用suspend()
,而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。