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. 确保只 ...
随机推荐
- @interface 注解详解
转:http://www.cnblogs.com/xdp-gacl/p/3622275.html 只为成功找方法,不为失败找借口! Java基础加强总结(一)——注解(Annotation) 一.认识 ...
- vs code打开文件显示的中文乱码
这种情况下,一般是编码格式导致的,操作办法: 鼠标点击之后,上面会弹出这个界面,双击选中 然后从UTF-8换到GB2312,或者自己根据情况,更改编码格式
- ubuntu14 中文显示问号
1 终端执行 sudo locale-gen zh_CN.UTF-8 2 终端执行 export LC_ALL=zh_CN.UTF-8
- Linux svn 服务器配置--转
转自 http://my.oschina.net/lionel45/blog/298305 留存备份. Linux搭建SVN 服务器 作者: 沈小然 日期:2014年 8月 5日 1 ...
- diary-2019.9.16
It has been observed by various scientists and nutritionists that it is better to have smaller and a ...
- Office 365管理员添加自定义域名
添加自定义域,以便Office 365允许更短.更熟悉的的电子邮件或用户ID用于服务 一.Office 365小型企业版添加自定义域名 1.使用Office 365管理员账户登陆到由世纪互联运营的Of ...
- CPU内核、用户模式
本文由是阅读该文章做下的笔记. CPU分内核与用户模式. 三言蔽之 内核模式下,应用可以直接存取内存,能够执行任何CPU指令.一般来说驱动运行在该模式下.内核模式的应用一旦崩溃,整个操作系统都会崩溃. ...
- [C#] 动态指定泛型类型
前言 今天为了程序能写好看一点,一直在纠结怎么指定动态泛型, 但是想想实用性好像不太大,可是把这技术忘掉太可惜XD 还是记录下来,以防忘记 以下程序范例 类 cs 123456789101112131 ...
- Mac环境下安装Redis
转自:http://www.jianshu.com/p/6b5eca8d908b -安装 下载安装包 redis-3.0.7.tar.gz 官网地址:http://redis.io/download ...
- h指数|JCR|ORCID|CCC|Research ID|BKCI|
h指数有如下缺点: 年龄大且平庸的学者比杰出的青年学者的h-index大.学科之间h指数的评价标准不同.有时候,审稿人暗示作者引用自己文章. 再此处可找到相关信息: JCR上可以查询到影响因子,以下是 ...