Java中有几种方法可以实现一个线程?用什么关键字修饰同步方法? stop()和suspend()方法为何不推荐使用?


java5以前,有如下两种:

第一种:

newThread(){}.start();这表示调用Thread子类对象的run方法,new Thread(){}表示一个Thread的匿名子类的实例对象,子类加上run方法后的代码如下:

new Thread() {

    publicvoid run() {

    }

}.start();

第二种:

newThread(new Runnable(){}).start();这表示调用Thread对象接受的Runnable对象的run方法,new Runnable(){}表示一个Runnable的匿名子类的实例对象,runnable的子类加上run方法后的代码如下:

new Thread(new Runnable() {

    publicvoid run() {

    }

}).start();

 

Java5开始,还有如下一些线程池创建多线程的方式:

ExecutorService pool = Executors.newFixedThreadPool(3);

for (int i = 0; i < 10;i++) {

    pool.execute(new Runable() {

        publicvoid run() {

        }

    });

}

Executors.newCachedThreadPool().execute(new Runable() {

    publicvoid run() {

    }

});

Executors.newSingleThreadExecutor().execute(new Runable() {

    publicvoid run() {

    }

});

有两种实现方法,分别使用new Thread()new Thread(runnable)形式,第一种直接调用threadrun方法,所以,我们往往使用Thread子类,即new SubThread()。第二种调用runnablerun方法。

 

1.      有两种实现方法,分别是继承Thread类与实现Runnable接口。可以的话使用线程池

2.      synchronized关键字修饰同步方法

3.      反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。suspend()方法容易发生死锁。调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。


猜你喜欢

转载自blog.csdn.net/panyuxin_/article/details/80782050