synchronized 块

方法一.
private class Worker implements Runnable {
    private Object mLock = new Object();
    private int spantime = 100;
    private boolean bResult = false;

    public Worker(int spantime) {
        Log.v(TAG, " TestThread constructor");
        this.spantime = spantime;

        new Thread(this).start();
    }

    @Override
    public void run() {
        Log.v(TAG, " TestThread run");

        synchronized (mLock) {
            try {
                Thread.sleep(spantime);
                bResult = true;
                Log.v(TAG, "current thread = " + Thread.currentThread().getName() +  " worker thread .... count = " + count++);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            mLock.notifyAll();
        }
    }

    boolean getResult() {
        synchronized (mLock) {
            try {
                mLock.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        return bResult;
    }
}


 方法二

 public void onClick(View v) {
         AThread thr = new AThread();
         thr.start();
         synchronized(thr){
                 try {
                         //Thread.sleep(1000);
                         thr.wait();
                         Log.v(TAG, " sleep 1000 --> 2");
                 } catch (InterruptedException e) {
                         // TODO Auto-generated catch block
                         e.printStackTrace();
                 }
         }

         synchronized(thr){
                 thr.mReady = true;
                 Log.v(TAG, " set mReady = true ---> 3");
                 thr.notifyAll();
         }
 }

 class AThread extends Thread{
         public boolean mReady = false;

         public AThread(){
                 super("Athread");
         }

         public void run(){
                 Looper.prepare();

                 synchronized (this){
                         try {
                                 Thread.sleep(1000);
                                 Log.v(TAG, " Thread notifyall -->1");
                                 this.notifyAll();
                         } catch (InterruptedException e) {
                                 // TODO Auto-generated catch block
                                 e.printStackTrace();
                         }
                 }

                 synchronized(this){
                         while (!mReady){
                                 try {
                                         wait();
                                         Log.v(TAG, " Thread wait ----> 4");
                                 } catch (InterruptedException e) {
                                         // TODO Auto-generated catch block
                                         e.printStackTrace();
                                 }
                         }
                 }

                 Looper.loop();
         }
 }


 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值