Android线程之AsyncTask_移动开发_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > 移动开发 > Android线程之AsyncTask

Android线程之AsyncTask

 2015/5/3 23:06:26  小破孩123  程序员俱乐部  我要评论(0)
  • 摘要:在之前的博客中为大家分享过关于Android多线程处理,想必大家对于Android为什么要使用多线程已经有了清晰的认识,我就在简单唠两句,Android规定UI界面的更新必须在在主线程进行,对于访问网络的耗时操作必须在子线程中执行,所以如果你想成为一名真正的Android开发工程师,多线程是你的必修课。本篇带给大家关于Android为我们封装好的一个简单的线程类AsyncTask。AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作
  • 标签:android android线程 线程

  在之前的博客中为大家分享过关于Android多线程处理,想必大家对于Android为什么要使用多线程已经有了清晰的认识,我就在简单唠两句,Android规定UI界面的更新必须在在主线程进行,对于访问网络的耗时操作必须在子线程中执行,所以如果你想成为一名真正的Android开发工程师,多线程是你的必修课。本篇带给大家关于Android为我们封装好的一个简单的线程类AsyncTask。

  AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作,提供接口反馈当前异步执行的程度(可以通过接口实现UI进度更新),最后反馈执行的结果给UI主线程.对于AsyncTask的详细介绍请大家查看:http://www.cnblogs.com/devinzhang/archive/2012/02/13/2350070.html

  AsyncTask中Android为我们封装了四个方法,具体的介绍请看下图:

  

  看到这里你大概对于AsyncTask已经有了一定的认识,下面我将以一个进度条效果带领大家进一步了解它。

  我们的布局文件activity_main.xml没有太多的控件,仅仅一个水平进度条:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <ProgressBar
        android:id="@+id/progressBar1"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true" />

</RelativeLayout>

  我们的主Activity:

public class MainActivity extends Activity {

    private ProgressBar mProgressBar;
    private MyAsyncTask mTast;
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mProgressBar = (ProgressBar) findViewById(R.id.progressBar1);
        mTast = new MyAsyncTask();//创建我们自定义的AsyncTask
        mTast.execute();
        
    }

    //防止我们重新打开时,线程出现等待
    @Override
    protected void onPause() {
        super.onPause();
        if(mTast != null && mTast.getStatus() == AsyncTask.Status.RUNNING){
            //cancel()方法只是将对应的AsyncTask标记为cancel状态,并不是真正的取消线程的执行。
            mTast.cancel(true);
        }
    }
    
    class MyAsyncTask extends AsyncTask<Void, Integer, Void>{

        //doInBackground()方法是AsyncTask中四个方法中唯一的不在主线程执行的方法
        @Override
        protected Void doInBackground(Void... arg0) {
            for(int i=0; i<100; i++){
                if(isCancelled()){//判断cancel的状态
                    break;
                }
                publishProgress(i);
                try {
                    Thread.sleep(300);//模拟网络加载
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            return null;
        }
        
        @Override
        protected void onProgressUpdate(Integer... values) {
            super.onProgressUpdate(values);
            if(isCancelled()){//判断cancel的状态
                return;
            }
            mProgressBar.setProgress(values[0]);
        }
        
    }
    
}

  代码上没有什么难点,关键部位已经为大家注释,大家如果还有疑问,请留言讨论。

  

发表评论
用户名: 匿名