首页 > 其他分享 > 安卓中实现异步任务(2)——使用AsyncTask实现

安卓中实现异步任务(2)——使用AsyncTask实现

时间:2022-10-22 22:40:54浏览次数:70  
标签:异步 void private progressBar AsyncTask 安卓中 import android textView

安卓中实现异步任务(2)——使用AsyncTask实现

问题背景

上次的文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章详细介绍这几种异步的具体实现。这篇讲得是基于asyncTask实现,持续更新。

实现demo

(1)实现我们的AsyncTask子类

import android.content.Context;
import android.os.AsyncTask;
import android.util.Log;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;

public class MyAsyncTask extends AsyncTask<Integer,Integer,Integer> {
    private final String TAG = "AsyncTask";
    private TextView textView;
    private ProgressBar progressBar;
    private Context context;
    public MyAsyncTask(TextView textView, ProgressBar progressBar, Context context) {
        this.textView = textView;
        this.progressBar = progressBar;
        this.context = context;
    }
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        Log.d(TAG,"onPreExecute(): " + Thread.currentThread().getName());
    }
    @Override
    protected Integer doInBackground(Integer... ints) {
        Integer count = ints[0];
        while (count < 10 && !isCancelled()){
            // isCancelled()表示判断当前任务是否被取消,防止在取消异步任务的时候循环不能及时停下
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            count++;
            Log.d(TAG,"doInBackground(): "+ Thread.currentThread().getName() +" "+count);
            publishProgress(count);
        }
        return count;
    }
    @Override
    protected void onPostExecute(Integer i) {
        Log.d(TAG,"onPostExecute(): "+ Thread.currentThread().getName());
        textView.setText(i + "");
    }
    @Override
    protected void onProgressUpdate(Integer... values) {
        Log.d(TAG,"onProgressUpdate(): " + Thread.currentThread().getName());
        textView.setText(values[0]+"");
        progressBar.setProgress(values[0]);
    }
    @Override
    protected void onCancelled() {
        Log.d(TAG,"nCancelled(): "+Thread.currentThread().getName());
        super.onCancelled();
        Toast.makeText(context,"任务取消成功", Toast.LENGTH_LONG).show();
    }
}

(2)新建我们的activity,对应layout布局如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:orientation="vertical"
    tools:context=".thread.AsyncTaskActivity">
    <TextView
        android:id="@+id/textView"
        android:hint="0"
        android:layout_gravity="center_horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

    <ProgressBar
        style="@android:style/Widget.ProgressBar.Horizontal"
        android:id="@+id/progressBar"
        android:progress="0"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <Button
            android:text="启动任务"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentStart="true"
            android:onClick="doTaskClick" />
        <Button
            android:text="取消任务"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentEnd="true"
            android:onClick="cancelTaskClick" />
    </RelativeLayout>

</LinearLayout>

(3)对应我们activity的代码如下:

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.TextView;

public class AsyncTaskActivity extends AppCompatActivity {
    private TextView textView;
    private ProgressBar progressBar;
    private MyAsyncTask myAsyncTask;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_async_task);
        textView= findViewById(R.id.textView);
        progressBar= findViewById(R.id.progressBar);
    }

    public void doTaskClick(View view){
        myAsyncTask = new MyAsyncTask(textView, progressBar,this);
        // 执行异步任务,传入初始参数
        myAsyncTask.execute(1);
    }

    public void cancelTaskClick(View view){
        // 取消异步任务
        myAsyncTask.cancel(true);
    }
}

执行结果如下:

安卓中实现异步任务(2)——使用AsyncTask实现

问题背景

上篇文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章详细介绍这几种异步的具体实现。这篇讲得是基于asyncTask实现,持续更新。

实现demo

(1)实现我们的AsyncTask子类

import android.content.Context;
import android.os.AsyncTask;
import android.util.Log;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;

public class MyAsyncTask extends AsyncTask<Integer,Integer,Integer> {
    private final String TAG = "AsyncTask";
    private TextView textView;
    private ProgressBar progressBar;
    private Context context;
    public MyAsyncTask(TextView textView, ProgressBar progressBar, Context context) {
        this.textView = textView;
        this.progressBar = progressBar;
        this.context = context;
    }
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        Log.d(TAG,"onPreExecute(): " + Thread.currentThread().getName());
    }
    @Override
    protected Integer doInBackground(Integer... ints) {
        Integer count = ints[0];
        while (count < 10 && !isCancelled()){
            // isCancelled()表示判断当前任务是否被取消,防止在取消异步任务的时候循环不能及时停下
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            count++;
            Log.d(TAG,"doInBackground(): "+ Thread.currentThread().getName() +" "+count);
            publishProgress(count);
        }
        return count;
    }
    @Override
    protected void onPostExecute(Integer i) {
        Log.d(TAG,"onPostExecute(): "+ Thread.currentThread().getName());
        textView.setText(i + "");
    }
    @Override
    protected void onProgressUpdate(Integer... values) {
        Log.d(TAG,"onProgressUpdate(): " + Thread.currentThread().getName());
        textView.setText(values[0]+"");
        progressBar.setProgress(values[0]);
    }
    @Override
    protected void onCancelled() {
        Log.d(TAG,"nCancelled(): "+Thread.currentThread().getName());
        super.onCancelled();
        Toast.makeText(context,"任务取消成功", Toast.LENGTH_LONG).show();
    }
}

(2)新建我们的activity,对应layout布局如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:orientation="vertical"
    tools:context=".thread.AsyncTaskActivity">
    <TextView
        android:id="@+id/textView"
        android:hint="0"
        android:layout_gravity="center_horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

    <ProgressBar
        style="@android:style/Widget.ProgressBar.Horizontal"
        android:id="@+id/progressBar"
        android:progress="0"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <Button
            android:text="启动任务"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentStart="true"
            android:onClick="doTaskClick" />
        <Button
            android:text="取消任务"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentEnd="true"
            android:onClick="cancelTaskClick" />
    </RelativeLayout>

</LinearLayout>

(3)对应我们activity的代码如下:

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.TextView;

public class AsyncTaskActivity extends AppCompatActivity {
    private TextView textView;
    private ProgressBar progressBar;
    private MyAsyncTask myAsyncTask;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_async_task);
        textView= findViewById(R.id.textView);
        progressBar= findViewById(R.id.progressBar);
    }

    public void doTaskClick(View view){
        myAsyncTask = new MyAsyncTask(textView, progressBar,this);
        // 执行异步任务,传入初始参数
        myAsyncTask.execute(1);
    }

    public void cancelTaskClick(View view){
        // 取消异步任务
        myAsyncTask.cancel(true);
    }
}

执行结果如下:

image.png 根据log,我们可以很清楚的看到asyncTask对应各方法所在的线程以及执行时机;

关键代码分析

持续更新。。。

标签:异步,void,private,progressBar,AsyncTask,安卓中,import,android,textView
From: https://blog.51cto.com/baorant24/5786130

相关文章

  • 安卓中实现异步任务(3)——使用HandlerThread实现
    #安卓中实现异步任务(3)——使用HandlerThread实现问题背景上篇文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章......
  • 安卓中实现异步任务(4)——使用线程池实现
    安卓中实现异步任务(4)——使用线程池实现问题背景上篇文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章详细介绍......
  • Generator函数异步应用
    协程协程的流程:协程A执行,执行到一半就将执行权转移给协程B,协程B交还执行权,然后A恢复执行。如下所示:function*asyncJob(){...varf=yieldreadFile(fileA);......
  • devexpress中grid控件教程 多线程异步加载数据,进度条展示
    devexpress中最强大的控件,要数它的Grid了。几乎任务数据都可以展示,但今天要用它做另一个功能。假设我们开发这样一款软件:视频编辑软件。里面有个功能,提取视频中的音频。一......
  • UEC++ 多线程(二) AsyncTask
    AsyncTaskAsyncTask系统实现的多线程与自己实现继承的FRunnable实现的原理相似,还可以利用UE4提供的线程池。当使用多线程不满意时也可以调用StartSynchronousTask改成主线......
  • 利用redis作为消息队列实现异步秒杀业务
    实现消费券秒杀的优化,在加入限时抢购的优惠券时,自动的将消费券的库存stock信息也加入到redis中(可设为抢购结束后过期)抢购之前在redis中进行库存是否充足(stock)、用户是否已......
  • android异步任务 访问网络 加载图片 解决方案大集合
    1.Handler+Thread异步执行任务在UI线程中开启子线程,使用Handler发消息,通知主线程更新UI​直接在UI线程中开启子线程来更新TextView显示的内容,运行程序我们会发现,如下......
  • vue中执行异步函数async和await的用法
    一、async基础用法async函数,会返回一个promise对象,可以用.then调用async函数中return的结果asyncfunctionhelloAsync(){return"返回结果";}con......
  • 安卓中实现异步任务的几种方式——常用的五种方式
    安卓中实现异步任务的几种方式问题背景在安卓日常开发中,经常需要使用到异步任务,现在把安卓中异步任务的几种主要使用方式简单总结一下,后面有需要会对他们每一种进行单独的......
  • python 异步任务框架 celery
    简介celery是一个分布式任务调度框架,由python编写。它专注于实时处理,在任务发布后,管理分配任务到不同的服务器,并取得结果。在执行任务分配时需要一个消息中间件(Broker),......