Android中使用AsyncTask
今天写作业用到了AnsyncTask,记录一下自己的使用情况
1.Android.os.AsyncTask类
1.AsyncTask类对线程间通讯进行了包装,我们可以使用简单的方式来让后台线程和UI线程通讯。后台线程执行异步操作,并且返回通知UI线程。这和异步执行的任务大概和我们平常所使用的handler差不多,AsyncTask在处理费时任务时性能会更好(使用确实比handler方便许多)。
2. AsyncTask对线程之间的的通讯做了包装,AsyncTask是抽象类,定义了三种泛型类型
public abstract class AsyncTask<Params, Progress, Result>
介绍一下这三个参数:
Params是启动任务是输入参数,与使用handler时发送的data类似。
Progress时任务执行的情况,我们在使用进度条时非常用用。
Result时后台执行任务最终返回的结果。
3.需要用到的四个方法
@Override
protected void onPreExecute() {
super.onPreExecute();
}
这个方法使在执行后台操作前被UI线程调用。可以实现一些组件的简单设置。可以不用实现
doInBackground(Params...)方法是紧跟着上一个方法执行后被执行,运行在后台,不可以操作UI。用来处理耗费时间的操作。通过Params参数我们创建线程实例是传入的参数可以在这里获取。可以通过publishProgress方法传入参数到下一个方法中获取(调用多次会传多个参数,以数组形式存储)。子类必须实现。
onProgressUpdate(Progress...)获取到publishProgress方法传入的参数我们可以用来操作UI组件。
onPostExecute(Result)方法获取在doInBackground(Params...)方法执行完后的返回值可以在界面上通过组件展示给用户。
还有一些方法就不多说了(其实是我没用到,偷个懒。)
4.使用时的注意事项
1) Task的实例必须在UI 线程中创建
2) execute方法必须在UI 线程中调用
3) 不要手动的调用onPreExecute(), onPostExecute(Result),doInBackground(Params...), onProgressUpdate(Progress...)这几个方法,需要在UI线程中实例化这个task来调用。
4) 该task只能被执行一次,否则多次调用时将会出现异常.参数顺序不能乱
5)参数类型是可以自己定义的
5.实例
>下边是我的一个练习实例。UI界面主要是获取输入的整数计算这个数以前的所有质数然后在界面显示计算进度,同时在完成后展示出来。(代码有点乱呀,不过能看嘻嘻)
package com.zzu.tangnanxing.a0746;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import android.app.ProgressDialog;
import android.content.Context;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.text.TextWatcher;
import android.view.View;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
private String string;
private int count = 0;
private int[] number;
private Button btn;
private TextView textView,textView1;
private ProgressDialog pd2 = null;
private int progressStart = 0;
private int add = 0;
private Context mContext = null;
private String factor = 2+",";
private Handler handler;
Mytask task;
private class Mytask extends AsyncTask<String,Integer,String> {
@Override
protected void onPreExecute() {
super.onPreExecute();
progressStart = 0;
add = 0;
//设置属性
pd2.setMax(100);
pd2.setTitle("计算"+string+"质数");
pd2.setMessage("计算中,请稍后...");
//设置不可以取消关闭进度条
pd2.setCancelable(false);
pd2.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
//设置是否显示进度,false显示
pd2.setIndeterminate(false);
pd2.show();
}
//接受输入的参数、执行任务中的耗时操作、返回线程任务的执行结果
@Override
protected String doInBackground(String... strings) {
//显示进度
System.out.println(strings[0]);
//计算质数操作
for (int i = 1; i <= Integer.valueOf(strings[0]); i++) {
boolean flag = true;
if (i == 1 || (i % 2) == 0) {
} else {
for (int j = 3; j < i; j += 2) {
if (i % j == 0) {
flag = false;
}
}
if (flag) {
factor = factor+(i+",");
count++;
// System.out.println(factor);
// System.out.println(count);
}
}
progressStart++;
try {
Thread.sleep(1);
} catch (InterruptedException e) {
e.printStackTrace();
}
publishProgress(progressStart,count);
}
//System.out.println(factor);
return factor;
}
@Override
protected void onProgressUpdate(Integer... values) {
super.onProgressUpdate(values);
//System.out.print(progressStart);
System.out.println(values[0]+" "+values[1]);
textView1.setText("计算第"+values[1]+"个");
pd2.setProgress(values[0]/(Integer.valueOf(string)/100));
if (values[1] >= Integer.valueOf(string)) {
pd2.dismiss();
}
}
@Override
protected void onPostExecute(String s) {
super.onPostExecute(s);
textView1.append(s);
pd2.dismiss();
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btn = findViewById(R.id.button);
textView = findViewById(R.id.textView);
textView1 = findViewById(R.id.textView1);
//获取输入内容
Button Button2 = findViewById(R.id.button2);
Button2.setOnClickListener(new imageDelete());
btn.setOnClickListener(new btnClickListener());
}
class imageDelete implements View.OnClickListener{
@Override
public void onClick(View v) {
textView.setText("");
}
}
class btnClickListener implements View.OnClickListener{
@Override
public void onClick(View v) {
string = textView.getText().toString();
if (!string.equals(" ") && string != null){
//创建mytask
pd2 = new ProgressDialog(MainActivity.this);
task = new Mytask();
task.execute(string);
// pd2.show();
//先使用普通方式handler
// new Thread(){
// @Override
// public void run() {
// super.run();
// while (progressStart < MAXVALUE){
// //进度条变化
// progressStart = 2*usetime();//
// handler.sendEmptyMessage(111);
// }
// }
// }.start();
}
}
}
}
Android中使用AsyncTask的更多相关文章
- Android中的AsyncTask异步任务的简单实例
在 Android中的AsyncTask异步任务的简介 一文中.已经对 安卓 异步任务操作做了简单的介绍.这里,直接将上文中的异步任务做了一个实例.实现异步操作更新UI线程,相比开启子线程更新来说逻辑 ...
- 深入了解Android中的AsyncTask
AsyncTask,即异步任务,是Android给我们提供的一个处理异步任务的类.通过此类,可以实现UI线程和后台线程进行通讯,后台线程执行异步任务,并把结果返回给UI线程. 我们知道,Androi ...
- Android中使用AsyncTask实现文件下载以及进度更新提示
Android提供了一个工具类:AsyncTask,它使创建需要与用户界面交互的长时间运行的任务变得更简单.相对Handler来说AsyncTask更轻量级一些,适用于简单的异步处理,不需要借助线程和 ...
- Android 中的AsyncTask
在后台下载图片,下载完成后更新UI是一个很常见的需求.在没有AsyncTask类之前,我们需要写许多thread和Handler的代码去实现这个功能,有了AsyncTask,一切变得简单了.下面摘抄谷 ...
- Android中使用Thread线程与AsyncTask异步任务的区别
最近和几个朋友交流Android开发中的网络下载问题时,谈到了用Thread开启下载线程时会产生的Bug,其实直接用子线程开启下载任务的确是很Low的做法,那么原因究竟如何,而比较高大上的做法是怎样? ...
- 详解Android中AsyncTask的使用
在Android中实现异步任务机制有两种方式,Handler和AsyncTask. Handler模式需要为每一个任务创建一个新的线程,任务完成后通过Handler实例向UI线程发送消息,完成界面的更 ...
- 具体解释Android中AsyncTask的使用
在Android中实现异步任务机制有两种方式,Handler和AsyncTask. Handler模式须要为每个任务创建一个新的线程,任务完毕后通过Handler实例向UI线程发送消息,完毕界面的更新 ...
- Android中AsyncTask异步
今天我们学习了 AsyncTack, 这是一个异步任务. 那么这个异步任务可以干什么呢? 因为只有UI线程,即主线程可以对控件进行更新操作.好处是保证UI稳定性,避免多线程对UI同时操作. 同时要把耗 ...
- Android中AsyncTask的简单用法 .
在开发Android应用时必须遵守单线程模型的原则: Android UI操作并不是线程安全的并且这些操作必须在UI线程中执行.在单线程模型中始终要记住两条法则: 1. 不要阻塞UI线程 2. 确保只 ...
随机推荐
- 吴裕雄--天生自然 pythonTensorFlow图形数据处理:TensorFlow图像处理函数
import numpy as np import tensorflow as tf import matplotlib.pyplot as plt #读取图片 image_raw_data = tf ...
- A brief introduction to complex analysis
\(\underline{Def:}\)A func \(U(\subset \mathbb{C}) \stackrel{f}\longrightarrow \mathbb{C}\)is (compl ...
- 获取cell上按钮事件
原由:点击cell上的按钮,无法获取button对应的cell位置 //获取按钮上层控件,也就是cell本身 AccountCell *cell= (AccountCell *)[按钮名称 super ...
- 分布式ID的简单总结
来源:郴州网站优化 简单总结一下流行的分布式id的实现方法 雪花算法 snowflake是twitter开源的分布式ID生成算法. 核心思想是:分布式ID固定是一个long型的数字,一个long型占8 ...
- c# winform清空ie缓存的几种方法
很明显 IE的缓存在其目录中显示的并不是真正的文件所处的位置,文件的位置是在隐藏的文件夹中,而且这个隐藏的文件夹我们一般找不到.在网上几种清空缓存的方法,在此我一一把代码和处理的效果显示出来.供大家参 ...
- Android之布局Application类
转载:https://blog.csdn.net/pi9nc/article/details/11200969 一 Application源码描述 * Base class for maintaini ...
- [SDOI2019]染色(DP)
好神的题啊! 看了这题只会第一个subtask,又参考了HN-CJ鸽王zsy的题解,实在太菜了. 暴力转移是O(nc2),很显然没有分.考虑子任务1,2,只需要转移包含已染色格子的列,然后状态数只有O ...
- Pay Back(模拟)
链接:https://ac.nowcoder.com/acm/contest/1086/C 题目描述 "Never a borrower nor a lender be." O h ...
- 27)PHP,视图
其实,视图就是一堆select形成的一个表格,但是这个表格也是存在一个数据库里面的,但是,他不会和一般的表格似得在数据库中显示,就好像虚拟存储器的那种感觉一样. 比如 必看我的一下句子 create ...
- Codeforces Round #599 (Div. 2)D 边很多的只有0和1的MST
题:https://codeforces.com/contest/1243/problem/D 分析:找全部可以用边权为0的点连起来的全部块 然后这些块之间相连肯定得通过边权为1的边进行连接 所以答案 ...