线程等待

今天发现同事的一段代码,妈的,当时没看懂。后来一问才知道线程等待。

它使用的场景就是在一个方法里面,调用AlertDialog api弹出了一个对话框,让用户选择,必须选择完之后才往下进行。

也就是用户不操作,那么这个方法是不会return的。

代码:

    private Calback             mAccountChangeCallback = new Calback() {
        private Object      mWaitLocker = new Object();
        private boolean     mConfim;

        @Override
        public boolean onBeforeAccountChange(String oldUserName, String newUserName) {
            if(TextUtils.isEmpty(oldUserName)) return true;
            if(oldUserName.equals(newUserName)) return true;
            BaseActivityHelper.hideProgressDialog(LoginActivity.this);
            //---请求用户确认
            String msgFormat = getString(R.string.login_msg_switch_account);
            String msgString = String.format(msgFormat, newUserName);
            BaseActivityHelper.setDialogEventListener(LoginActivity.this,new ListenerDialogEvent() {

                @Override
                public void onEvent(int event, Object currObj, Object param, int index) {
                    mConfim = currObj == null ? false : (Boolean) currObj;
                    synchronized (mWaitLocker) {
                        mWaitLocker.notifyAll();
                    }
                }
            }, null);

            Message msg = new Message();
            String[] result = new String[]{getString(R.string.login_switch_account) , msgString};
            msg.what = MSG.MSG_APP_SHOW_DIALOG_CUSTOM;
            msg.arg1 = R.array.alert_btn_d;
            msg.arg2 = 0;
            msg.obj  = result;
            mHandler.sendMessage(msg);

            //---等待用户确认
            synchronized (mWaitLocker) {
                try {
                    mWaitLocker.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }


            return mConfim;
        }

        @Override
        public boolean onAfterAccountChange(String oldUserName,
                String newUserName) {
            return false;
        }
    };

1.private Object mWaitLocker = new Object();
2.主要是这个方法:onBeforeAccountChange

在return之前加了一个,等待用户去点击:

  //---等待用户确认
            synchronized (mWaitLocker) {
                try {
                    mWaitLocker.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }

wait线程等待,这个方法就不返回,就不往下走了。

3.用户点击之后就会回调

 @Override
                public void onEvent(int event, Object currObj, Object param, int index) {
                    mConfim = currObj == null ? false : (Boolean) currObj;
                    synchronized (mWaitLocker) {
                        mWaitLocker.notifyAll();
                    }
                }
            }, null);

这时候通知所有这个加锁的线程去唤醒。
notifyAll()

注:
1.调试一定要一步一行的观察。

转载于:https://www.cnblogs.com/caoxinyu/p/6647773.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值