线程中的sleep和wait的区别

sleep指线程被调用时,占着CPU不工作,形象地说明为“占着CPU睡觉”(霸道的占用系统资源,独享系统资源不释放),此时,系统的CPU部分资源被占用,其他线程无法进入,会增加时间限制。
wait指线程处于进入等待状态,形象地说明为“等待使用CPU”(释放系统资源给其他的线程使用),此时线程不占用任何资源,不增加时间限制。
所以
sleep(500L)意思为:占用CPU,线程休眠500毫秒
wait(500L)意思为:不占用CPU,线程等待500毫秒
### Java 线程 Sleep Wait 方法的区别及用法 #### 所属类的不同 `sleep()` 是 `Thread` 类的静态方法,而 `wait()` 则是 `Object` 类的方法。这意味着 `sleep()` 可以直接通过线程对象调用,而 `wait()` 需要依赖于某个特定的对象实例来调用[^1]。 #### 使用方式上的差异 对于 `sleep(long millis)` 来说,在指定的时间内它会让当前正在执行的线程暂时休眠,并不会释放任何锁资源。相反地,当调用了某对象的 `wait()` 后,不仅会使当前线程进入等待状态直到其他线程唤醒该线程(通过调用相同对象上的 notify 或 notifyAll),而且还会立即放弃对该同步监视器的所有权,即会释放掉已经持有的锁[^2]。 #### 前置条件的要求 为了能够成功调用 `wait()` ,必须先获得相应对象内部锁,通常是在 synchronized 代码块或方法里完成这一操作;但是 `sleep()` 并不需要这样的前置条件就可以正常工作[^3]。 #### 错误处理机制 如果在睡眠期间被打断,则抛出 InterruptedException 异常给上层捕获并做进一步处理。而对于处于 waiting 的线程而言,除了上述提到的通知外,还可以因为超时自动醒来或是同样由于中断事件的发生而导致异常抛出。 ```java // sleep 示例 public class SleepExample { public static void main(String[] args) throws InterruptedException { System.out.println("Start sleeping..."); Thread.sleep(2000); // 让主线程暂停两秒后再继续往下运行 System.out.println("Woke up after two seconds."); } } // wait/notify 示例 class Buffer { private boolean full = false; public synchronized void set(){ while(full){ try{ this.wait(); // 当缓冲区满的时候就让设置数据的线程等待 }catch (InterruptedException e){} } // 设置数据... full=true; this.notify(); } public synchronized int get(){ while(!full){ try{ this.wait(); // 如果没有可取的数据则让消费者线程等待 } catch (InterruptedException e){} } // 获取数据... full=false; this.notify(); return 0; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值