java读书笔记-Thread类

一、线程的三个常用方法


二、线程死锁图解

         Thread1锁住了上面的对象,等待锁住下面的对象来完成执行过程。但是下面的对象被Thread2锁住了,它也等着锁住上面的对象来完成执行,因此陷入了死锁。

三、死锁小程序

  public class TestDeadLock implements Runnable {
      public int flag = 1;
      static Object o1 = new Object(), o2 = new Object();
      public void run() {
      System.out.println("flag=" + flag);
          if(flag == 1) {
              synchronized(o1) {
                  try {
                      Thread.sleep(500);
                  } catch (Exception e) {
                      e.printStackTrace();
                  }
                  synchronized(o2) {
                      System.out.println("1");    
                  }
              }
          }
          if(flag == 0) {
              synchronized(o2) {
                  try {
                      Thread.sleep(500);
                  } catch (Exception e) {
                      e.printStackTrace();
                  }
                  synchronized(o1) {
                      System.out.println("0");
                  }
              }
          }
      }   
      
      public static void main(String[] args) {
          TestDeadLock td1 = new TestDeadLock();
          TestDeadLock td2 = new TestDeadLock();
          td1.flag = 1;
          td2.flag = 0;
          Thread t1 = new Thread(td1);
          Thread t2 = new Thread(td2);
          t1.start();
          t2.start();
          
      }
  }

四、面试题

下面举个小例子:

  
  public class TT implements Runnable {
      int b = 100;
      
      public synchronized void m1() throws Exception{
          //Thread.sleep(2000);
          b = 1000;
          Thread.sleep(5000);
          System.out.println("b = " + b);
      }
      
      public  void m2() throws Exception {
          Thread.sleep(2500);
          b = 2000;
      }
      
      public void run() {
          try {
              m1();
          } catch(Exception e) {
              e.printStackTrace();
          }
      }
      
      public static void main(String[] args) throws Exception {
          TT tt = new TT();
          Thread t = new Thread(tt);
          t.start();
          
          tt.m2();
          System.out.println(tt.b);
      }
  }

上面的输出结果是:2000

五、wait()跟sleep()区别

1)wait时别的线程可以访问锁定对象(调用wait方法的时候必须锁定该对象)

2)sleep时别的线程也不可以访问锁定对象

2)Thread.sleep()与Object.wait()二者都可以暂停当前线程,释放CPU控制权,主要的区别在于Object.wait()在释放CPU同时,释放了对象锁的控制,而在同步块中的Thread.sleep()方法并不释放锁,仅释放CPU控制权。

六、wait()跟notify()方法

           1)wait()方法与notify()必须要与synchronized(resource)一起使用。(也就是wait与notify针对已经获取了resource锁的线程进行操作,从语法角度来说就是Obj.wait(),Obj.notify必须在synchronized(Obj){...}语句块内。)

          2) wait和notify方法均可释放对象的锁,但wait同时释放CPU控制权,即它后面的代码停止执行,线程进入阻塞状态,而notify方法不立刻释放CPU控制权,而是在相应的synchronized(){}语句块执行结束,再自动释放锁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值