解析异步消息处理机制

在平时的工作中,难免会涉及到异步消息的处理,需要从子线程回到主线程去工作!这个时候就需要采用异步工作了。
简单点的有:
第一种:直接通过runOnUiThread从只线程回到主线程

runOnUiThread(new Runnable() {
            @Override
            public void run() {
                
            }
        });
```说到thread线程,提一下线程池的使用:
  1:通过ThreadPoolExecutor构造器创建默认的管理器
  2,间接的通过ExecutorService去创建四种不同类型的:FixedThreadPool, CacheThreadPool, SingleThreadExecutor, ScheduleThreadPool

第二种:使用Handler来实现来处理,这个我们就太熟悉了,通过创建主线程的中handler对象!当sendMessage消息后,handlerMessage接收到消息后,在主线程中执行ui操作。

第三种:使用AsyncTask来实现异步消息,简单代码实例如下

/**
* AsyncTask属于抽象类,所以使用的时候,必须创建子类去继承,其中三个参数的含义如下
* params:在执行AsyncTask是需要传入的参数,可用于在后台任务中使用,doInBackground方法的参数类型
* 在execute() 传入,可变长参数,跟doInBackground(Void… params) 这里的params类型一致
* progress:后台任务执行的时候,如果需要界面上显示当前的进度,则使用这里指定的泛型作为进度单位
* ,跟onProgressUpdate(Integer… values) 的values的类型一致
* result:当任务执行完毕后,如果需要对结果进行返回,则使用这里指定的泛型作为返回值类型
* 跟doInBackground 返回的参数类型一致,且跟onPostExecute(Boolean s) 的s参数一致,在耗时操作执行完毕调用。
*/
private class MyDownTask extends AsyncTask<Void,Integer,Boolean>{

    //该方法会在后台任务开始执行之前调用,用于进行一些界面上的初始化操作,比如显示一个进度条对话框
    @Override
    protected void onPreExecute() {
        //显示进度对话框
        mProgressDialgo.show();
        super.onPreExecute();
    }

    //此方法子子线程中执行,其他方法都是在主线程中执行,执行完成后通过return语句来将任务的执行结果返回
    //在内部调用publishProgress(Progress...)来通知onProgressUpdate的方法的调用
    @Override
    protected Boolean doInBackground(Void... params) {
        try{
            while (true){
                int downProgressData = doDownLoad();
                //该方法就相当于handler消息机制
                publishProgress(downProgressData);
                if(downProgressData == 100) {
                    break;
                }
            }
        }catch (Exception e){
            e.printStackTrace();
        }
        return true;
    }

    //在后台调用了publishProgress(Progress...)后,该方法很快就会被调用,其参数就是由publishProgress()传递过来
    //实现对UI界面的更新
    @Override
    protected void onProgressUpdate(Integer... values) {
        //更新具体的进度
        mProgressDialgo.setMessage("加载"+values[0]+"%");
        super.onProgressUpdate(values);
    }

    //当后台任务执行完毕,即doInBackground通过rerurn语句进行返回时,该方法很快会被调用
    //可以做提醒任务执行结果的反馈,和关闭对话框等
    @Override
    protected void onPostExecute(Boolean aBoolean) {
        //关闭进度
        mProgressDialgo.dismiss();
        if(aBoolean){
            Toast.makeText(MainActivity.this,"加载成功",Toast.LENGTH_LONG).show();
        }else {
            Toast.makeText(MainActivity.this,"加载失败",Toast.LENGTH_LONG).show();
        }
    }
}
其中//在主线程中创建MyDownTask 并执行
        MyDownTask myDownTask = new MyDownTask();
        myDownTask.execute();

**特别说明:在3.0以后版本中
默认AsyncTask是串行执行,调用的是.execute()
如果想变成并行执行,则需要调用executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR,"");执行**

以上:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值