java中的sleep()与wait()区别
2015-11-04 09:39
441 查看
1、对于sleep()方法,我们首先要知道该方法是属于Thread类中的。而wait()方法,则是属于Object类中的。
2、sleep()方法导致了程序暂停执行指定的时间,让出cpu給其他线程,但是他的监控状态依然保持着,当指定的时间到了又会自动恢复运行状态。在调用sleep()方法的过程中,线程不会释放对象锁。而当调用wait()方法的时候,线程会放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象调用notify()方法后本线程才进入对象锁定池准备
获取对象锁进入运行状态。
eg:
public class TestThread {
public static void main(String [] args)
{
new Thread(new Thread1()).start();
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
new Thread(new Thread2()).start();
}
private static class Thread1 implements Runnable{
@Override
public void run() {
synchronized(TestThread.class)
{
System.out.println("线程一启动。。。。。");
System.out.println("线程一wait.....");
try {
TestThread.class.wait();
} catch (Exception e) {
// TODO: handle exception
}
System.out.println("线程一在此运行。。。。。");
System.out.println("线程一结束.....");
}
}
}
private static class Thread2 implements Runnable{
@Override
public void run() {
synchronized (TestThread.class) {
System.out.println("thread2启动....");
System.out.println("thread2 is sleep....");
//只有针对此对象调用notify()方法后本线程才进入对象锁定池准备获取对象锁进入运行状态。
TestThread.class.notify();
//==================
//区别
//如果我们把代码:TestD.class.notify();给注释掉,即TestD.class调用了wait()方法,但是没有调用notify()
//方法,则线程永远处于挂起状态。
try {
//sleep()方法导致了程序暂停执行指定的时间,让出cpu给其他线程,
//但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。
//在调用sleep()方法的过程中,线程不会释放对象锁。
Thread.sleep(5000);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("thread2 is going on....");
System.out.println("thread2 is over!!!");
}
}
}
}
结果:
线程一启动。。。。。
线程一wait.....
thread2启动....
thread2 is sleep....
thread2 is going on....
thread2 is over!!!
线程一在此运行。。。。。
线程一结束.....
如果注释掉代码:
TestThread.class.notify();
结果:
线程一启动。。。。。
线程一wait.....
thread2启动....
thread2 is sleep....
thread2 is going on....
thread2 is over!!!
2、sleep()方法导致了程序暂停执行指定的时间,让出cpu給其他线程,但是他的监控状态依然保持着,当指定的时间到了又会自动恢复运行状态。在调用sleep()方法的过程中,线程不会释放对象锁。而当调用wait()方法的时候,线程会放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象调用notify()方法后本线程才进入对象锁定池准备
获取对象锁进入运行状态。
eg:
public class TestThread {
public static void main(String [] args)
{
new Thread(new Thread1()).start();
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
new Thread(new Thread2()).start();
}
private static class Thread1 implements Runnable{
@Override
public void run() {
synchronized(TestThread.class)
{
System.out.println("线程一启动。。。。。");
System.out.println("线程一wait.....");
try {
TestThread.class.wait();
} catch (Exception e) {
// TODO: handle exception
}
System.out.println("线程一在此运行。。。。。");
System.out.println("线程一结束.....");
}
}
}
private static class Thread2 implements Runnable{
@Override
public void run() {
synchronized (TestThread.class) {
System.out.println("thread2启动....");
System.out.println("thread2 is sleep....");
//只有针对此对象调用notify()方法后本线程才进入对象锁定池准备获取对象锁进入运行状态。
TestThread.class.notify();
//==================
//区别
//如果我们把代码:TestD.class.notify();给注释掉,即TestD.class调用了wait()方法,但是没有调用notify()
//方法,则线程永远处于挂起状态。
try {
//sleep()方法导致了程序暂停执行指定的时间,让出cpu给其他线程,
//但是他的监控状态依然保持者,当指定的时间到了又会自动恢复运行状态。
//在调用sleep()方法的过程中,线程不会释放对象锁。
Thread.sleep(5000);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("thread2 is going on....");
System.out.println("thread2 is over!!!");
}
}
}
}
结果:
线程一启动。。。。。
线程一wait.....
thread2启动....
thread2 is sleep....
thread2 is going on....
thread2 is over!!!
线程一在此运行。。。。。
线程一结束.....
如果注释掉代码:
TestThread.class.notify();
结果:
线程一启动。。。。。
线程一wait.....
thread2启动....
thread2 is sleep....
thread2 is going on....
thread2 is over!!!
相关文章推荐
- java读取资源文件的方法
- Java-File
- Java学习:Timer与ScheduledExecutorService的区别
- Spring MVC篇二、使用JdbcTemplate进行数据库操作
- 阿里RocketMq试用记录+简单的Spring集成
- SpringMvc+Mybatis多数据源配置
- 用C#.NET调用Java开发的WebService传递int,double问题,出现java无法获得值!
- spring,mybatis,atomikos多数据源的整合
- Java NIO通信框架: Netty
- java中的Runtime类和Process类
- 控制台的8位信息位的海明校验码
- eclipse maven 刷新报错
- Eclipse常用快捷键
- java 10 进制 转换为 2 进制, 利用递归
- java正则表达式基础
- 从”JAVA“而终 8:java循环判断语句讲解
- 编译器指令重排序 和 Java 内存模型
- SpringMVC和Struts2比较
- java代理 InvocationHandler接口实现
- Java中的静态方法调用静态成员变量