wait():使一个线程处于等待状态,并释放所持对象的锁;
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉InterruptedException异常;
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法时,并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级;
notifyAll():唤醒所有处于等待状态的的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争。
sleep()是线程类Thread的方法,导致此线程暂停指定时间,给其他线程执行机会,但是监控状态依然保持,到时间后自动恢复。调用此方法不会释放对象锁。
wait()是Object类的方法,对此对象调用wait方法导致本线程释放对象锁,进入等待此对象的等待锁定池,只有针对此方法发出notify方法或者notifyAll方法后线程才进入对象锁定池准备获得对象锁进入运行状态。
启动一个线程是调用start()方法,使线程所代表的虚拟机处于可运行状态,这意味着它可以由JVM调度并执行。这并不是意味着线程就会立即执行。run()方法可以产生必须退出的标志来停止一个线程。
多线程的三种实现方式:继承Thread类;实现Runnable接口;实现Callable接口。
同步的实现方法:Synchronize,wait,notify。
同步和异步:如果数据将在线程间共享,例如正在写的数据以后可能被另一个线程读到,或者正在读的数据被另一个线程谢过了,那么就必须进行同步存取;当应用程序在对象上调用了一个需要花费很时间来执行的方法,并且不希望让程序等待方法的返回时,就应该使用异步编程,在很多情况下采用异步编程往往更有效率。
下面附一段代码
//设计4个线程,其中两个线程每次对j增加1,另外两个线程对j每次减少1。
public class ThreadTest1 {
private int j;
public static void main(String args[]) {
ThreadTest1 tt = new ThreadTest1();
Inc inc = tt.new Inc();
Dec dec = tt.new Dec();
for (int i = 0; i < 2; i++) {
Thread t = new Thread(inc);
t.start();
t = new Thread(dec);
t.start();
}
}
private synchronized void inc() {
j++;
System.out.println(Thread.currentThread().getName() + "-inc:" + j);
}
private synchronized void dec() {
j--;
System.out.println(Thread.currentThread().getName() + "-dec:" + j);
}
class Inc implements Runnable {
public void run() {
for (int i = 0; i < 100; i++) {
inc();
}
}
}
class Dec implements Runnable {
public void run()
for (int i = 0; i < 100; i++) {
dec();
}
}
}
}
本文深入探讨了Java中线程控制的关键方法,包括wait(), sleep(), notify()和notifyAll()的功能与使用场景,以及线程的启动和同步机制。通过实例代码展示了如何在多线程环境中正确地使用这些方法。

被折叠的 条评论
为什么被折叠?



