异步任务-AsyncTack基本使用

2024-08-30 01:32

本文主要是介绍异步任务-AsyncTack基本使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AsyncTask的基本使用方法

  在Day25我们讲解了Handler, 可以实现子线程数据传递到主线程(UI线程) 中去, 这样可以解决一些网络下载, 文件传输等需要子线程的完成的工作, 但是它也有一个小瑕疵 , 就是封装性不够好, 那就今天我们就要来说一下AsyncTask

介绍一下如何使用

1, 继承AsyncTask

public class MyTask extends AsyncTask<Params, Progrss, Result> 

我们来说一下这三个泛型的作用:

Params: 调用异步任务时传入的类型 ;

Progress : 字面意思上说是进度条, 实际上就是动态的由子线程向主线程publish数据的类型

Result : 返回结果的类型

2, 重写这个类的抽象方法doInBackground, 当然它也有几个方法需要重写, 我们一一看来

doInBackground(抽象方法, 必须实现)


/* 唯一执行在子线程中的方法*   所以不可以进行UI的更新* @param params* @return*/
@Override//返回值: Result       参数: Param
protected String doInBackground(TextView... params) {text = params[0];Random random = new Random();for (int i = 0; i < 50; i++) {//要进行进度的更新publishProgress(i);//不能直接调用onProgressUpdate方法,//这样会使得onProgressUpdate在子线程中运行try {Thread.sleep(random.nextInt(10) * 10);} catch (InterruptedException e) {e.printStackTrace();}}return "已完成";
}

下面三个方法根据具体情况选择使用

   //执行doInBackground之前调用@Overrideprotected void onPreExecute() {super.onPreExecute();}
    @Override//与publishProgress(i)对应protected void onProgressUpdate(Integer... values) {super.onProgressUpdate(values);text.setText(String.valueOf(values[0]));}
 //在doInBackground之后执行@Override // 参数s为 Resultprotected void onPostExecute(String s) {super.onPostExecute(s);text.setText(s);}

3, 执行异步任务

有两种方式, 我已经把区别写在了注释中

/*直接execute异步任务, 都是同一线程去执行
*/text = (TextView) findViewById(R.id.main_text1);
new MyTask().execute(text);
text = (TextView) findViewById(R.id.main_text2);
new MyTask().execute(text);
text = (TextView) findViewById(R.id.main_text3);
new MyTask().execute(text);
text = (TextView) findViewById(R.id.main_text4);
new MyTask().execute(text);
/*启动多条线程来执行异步任务API11以上可以使用
*/ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(4);text = (TextView) findViewById(R.id.main_text1);new MyTask().executeOnExecutor(executor, text);text = (TextView) findViewById(R.id.main_text2);new MyTask().executeOnExecutor(executor, text);text = (TextView) findViewById(R.id.main_text3);new MyTask().executeOnExecutor(executor, text);text = (TextView) findViewById(R.id.main_text4);new MyTask().executeOnExecutor(executor, text);

注意: 如果我们直接去execute我们的任务, 它(任务) 只会在同一个子线程中运行, 所以上述第一种方式启动时, 四个任务顺次执行(就是一个任务执行完了再执行另一个); 而第二种方式, 给它创建了线程池, 这样会自动给它创建新的子线程, 所有的任务不是顺序执行, 而是几个线程”同时执行”

获取网络数据呈现在Webview和下载图片和其共存的案例

1, 首先我们要来一个布局, 具体需求是这样的, 在WebView之上有个ImageView, 并且, ImageView可以随WebView滚动, 所以这个时候我们想到了用ScrollView, 但是大家一定不要忘记, ScrollView只能包含一个控件, 所以我们可以用LinearLayout包裹一下即可

<ScrollView
    android:layout_width="match_parent"android:layout_height="match_parent"><LinearLayout
        android:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"><ImageView
            android:id="@+id/main2_image"android:layout_width="wrap_content"android:layout_height="wrap_content" /><WebView
            android:id="@+id/main2_web"android:layout_width="match_parent"android:layout_height="match_parent"/></LinearLayout>
</ScrollView>

2, 接下来我们要有一个实体类, 用来存放从网页上下载的内容(这里加注解原因在于我们要使用GSON解析来自网页的内容)

public class Entry {@SerializedName("title")private String title;@SerializedName("message")private String message;@SerializedName("img")private String image;public String getTitle() {return title;}...//省略其余getter和setter方法public void setImage(String image) {this.image = image;}
}

3, 那我们接下解决的问题就是 如何下载图片? 如何下载web内容? , 那我们写两个通用的工具类

下载工具类(通用型)

/*** Created by Lulu on 2016/8/31.* <p/>* 通用下载工具类*/
public class NetWorkTask<T> extends AsyncTask<NetWorkTask.Callback<T>, Void, Object> {private NetWorkTask.Callback<T> callback;private Class<T> t;private String url;public NetWorkTask(String url, Class<T> t) {this.url = url;this.t = t;}@Overrideprotected Object doInBackground(Callback<T>... params) {callback = params[0];try {HttpURLConnection connection = (HttpURLConnection) new URL(url).openConnection();connection.setRequestMethod("GET");connection.setDoInput(true);int code = connection.getResponseCode();if (code == 200) {InputStream is = connection.getInputStream();ByteArrayOutputStream bos = new ByteArrayOutputStream();byte[] buffer = new byte[102400];int length;while ((length = is.read(buffer)) != -1) {bos.write(buffer, 0, length);}return bos.toString("UTF-8");} else {return  new RuntimeException("服务器异常");}} catch (Exception e) {e.printStackTrace();return e;}}@Overrideprotected void onPostExecute(Object o) {super.onPostExecute(o);if(o instanceof String) {String str = (String) o;Gson gson = new Gson();T t = gson.fromJson(str, this.t);callback.onSuccess(t);}if( o instanceof Exception) {Exception e = (Exception) o;callback.onFailed(e);}}public interface Callback<S> {void onSuccess(S t);void onFailed(Exception e);}
}

图片加载器(通用型)


/*** Created by Lulu on 2016/8/31.* 图片网络加载器* 下载成功返回Bitmap* 否则返回null*/
public class ImageLoader extends AsyncTask<String, Void, Bitmap>{private ImageView image;public ImageLoader(ImageView image) {this.image = image;image.setImageResource(R.mipmap.ic_launcher);}@Overrideprotected void onPreExecute() {super.onPreExecute();}@Overrideprotected Bitmap doInBackground(String... params) {String url = params[0];try {HttpURLConnection connection = (HttpURLConnection) new URL(url).openConnection();connection.setRequestMethod("GET");connection.setDoInput(true);int code = connection.getResponseCode();if (code == 200) {InputStream is = connection.getInputStream();return BitmapFactory.decodeStream(is);}} catch (IOException e) {e.printStackTrace();}return null;}@Overrideprotected void onPostExecute(Bitmap bitmap) {super.onPostExecute(bitmap);if (bitmap != null) {image.setImageBitmap(bitmap);} else {image.setImageResource(R.mipmap.failed);}}
}

4, 测试Activity

注意: 看如何解决大图在webView中不左右滑动的问题!

public class Main2Activity extends AppCompatActivity implements NetWorkTask.Callback<Entry>{private WebView web;private ImageView image;//解决大图在webView中不左右滑动的问题private static final String CSS = "<style>img{max-width:100%} </style>";private String title;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main2);web = (WebView) findViewById(R.id.main2_web);image = (ImageView) findViewById(R.id.main2_image);new NetWorkTask<>("http://www.tngou.net/api/top/show?id=13122", Entry.class).execute(this);}@Overridepublic void onSuccess(Entry t) {web.loadDataWithBaseURL("", t.getMessage(), "text/html; charset=utf-8", "UTF-8", null);new ImageLoader(image).execute("https://img-blog.csdn.net/20160829134937003");}@Overridepublic void onFailed(Exception e) {web.loadDataWithBaseURL("", "加载失败", "text/html; charset=utf-8", "UTF-8", null);}
}

5, 效果图:

这里写图片描述

这篇关于异步任务-AsyncTack基本使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119418

相关文章

python之uv使用详解

《python之uv使用详解》文章介绍uv在Ubuntu上用于Python项目管理,涵盖安装、初始化、依赖管理、运行调试及Docker应用,强调CI中使用--locked确保依赖一致性... 目录安装与更新standalonepip 安装创建php以及初始化项目依赖管理uv run直接在命令行运行pytho

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Kotlin 枚举类使用举例

《Kotlin枚举类使用举例》枚举类(EnumClasses)是Kotlin中用于定义固定集合值的特殊类,它表示一组命名的常量,每个枚举常量都是该类的单例实例,接下来通过本文给大家介绍Kotl... 目录一、编程枚举类核心概念二、基础语法与特性1. 基本定义2. 带参数的枚举3. 实现接口4. 内置属性三、

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python Flask实现定时任务的不同方法详解

《PythonFlask实现定时任务的不同方法详解》在Flask中实现定时任务,最常用的方法是使用APScheduler库,本文将提供一个完整的解决方案,有需要的小伙伴可以跟随小编一起学习一下... 目录完js整实现方案代码解释1. 依赖安装2. 核心组件3. 任务类型4. 任务管理5. 持久化存储生产环境

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

C#中SortedSet的具体使用

《C#中SortedSet的具体使用》SortedSet是.NETFramework4.0引入的一个泛型集合类,它实现了一个自动排序的集合,内部使用红黑树数据结构来维护元素的有序性,下面就来介绍一下如... 目录基础概念主要特性创建和初始化基本创建方式自定义比较器基本操作添加和删除元素查询操作范围查询集合运