AsyncTask内部类可能会产生内存泄露的问题

解决上述内部类可能引起的内存泄露问题的方法

  • 将AsyncTask或者Thread的子类作为单独的类文件,不持有Activity的强引用
  • 将AsyncTask或者Thread的子类使用static修饰,则不会隐式持有Activity的强引用
  • 如果是匿名内部类,则需要将其对象设置成成员属性,使用static修饰就不会隐式持有Activity的强引用。

异步任务是我们经常要使用的东西,android中提供了一套解决方案,从异步任务的开始到结束,相当完善。本实例没有任何应用价值,只是说明了AsyncTask中各个函数的调用顺序。

具体的结果看下面的Log输出即可:

异步任务类:

AsyncTaskTest.java

package com.kale.asynctask;

import java.net.URL;

import android.R.integer;
import android.os.AsyncTask; /**
* @author:Jack Tony
* @tips :
* 必须在UI线程中创建AsyncTask实例
* 必须在UI线程中执行AsyncTask的execute方法
* 每个AsyncTask只能执行一次,不能多次调用。要用的话再生成一个对象再执行即可
* @date :2014-8-1
*/
/**
* @param
* execute传来的参数是第三个参数
* 第一个参数的类型提供给publishProgress做参数(可变长的数组)
* 第二个参数定义的是onProgressUpdate的参数类型(可变长的数组)
* 第三个参数作为doInBackground返回值的类型,返回给onPostExecute做形参
*/
public class AsyncTaskTest extends AsyncTask<URL, Integer, String>{ /* (非 Javadoc)
* @see android.os.AsyncTask#onPreExecute()
* 开始异步任务前会调用此方法,这个方法执行在UI线程中
*/
@Override
protected void onPreExecute() {
System.out.println("onPreExecute 开始执行");
System.out.println("onPreExecute 执行初始化操作,执行UI操作");
System.out.println("onPreExecute 所在的线程:"+Thread.currentThread().getName());
System.out.println("onPreExecute 执行完毕,开始执行doInBackground");
}
/*
* @see android.os.AsyncTask#doInBackground(Params[]),里面就是个可变长度的数组
* 里面写后台线程要完成任务,里面可以调用publishProgress(values);更新进度
* 可以有变长的参数,对个数无要求
*/
@Override
protected String doInBackground(URL... params) {
System.out.println("doInBackground 开始执行");
System.out.println("doInBackground 执行耗时的异步任务");
System.out.println("doInBackground 所在的线程:"+Thread.currentThread().getName());
System.out.println("doInBackground 执行耗时的异步任务");
System.out.println("doInBackground 中调用publishProgress更新下视图");
for (int i = 0; i < 3; i++) {
publishProgress(i);//这里传的值是给onProgressUpdate做参数的,这里传的也是一个可变长的数组
try {
Thread.sleep(100);
} catch (InterruptedException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
System.out.println("doInBackground 执行完毕,准备执行onPostExecute");
return "doInBackground执行完后的结果";
} /* (非 Javadoc)
* @see android.os.AsyncTask#onProgressUpdate(Progress[])
* 在doInBackground中调用publishProgress时会执行这个方法,主要用来更新进度
* 执行在UI线程中
*/
@Override
protected void onProgressUpdate(Integer... values) {
System.out.println("onProgressUpdate 开始执行,更新UI视图,一般是进度");
System.out.println("onProgressUpdate 执行第【"+(values[0].intValue()+1)+"】次更新操作");
System.out.println("onProgressUpdate 所在的线程:"+Thread.currentThread().getName());
System.out.println("onProgressUpdate 执行完毕,更新操作结束");
} /* (非 Javadoc)
* @see android.os.AsyncTask#onPostExecute(java.lang.Object)
* 在doInBackground执行完后,系统将doInBackground方法返回的参数作为形参传递到这个方法中
* 它执行在UI线程中
*/
@Override
protected void onPostExecute(String result) {
System.out.println("onPostExecute 开始执行,更新UI视图");
System.out.println("onPostExecute 接收到的处理结果是:【"+result+"】");
System.out.println("onPostExecute 执行收尾操作");
System.out.println("onPostExecute 所在的线程:"+Thread.currentThread().getName());
System.out.println("onPostExecute 执行完毕,异步任务完全结束");
}
}

MainActivity.java

package com.kale.asynctask;

import java.net.MalformedURLException;
import java.net.URL; import android.app.Activity;
import android.os.Bundle; public class MainActivity extends Activity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
AsyncTaskTest async = new AsyncTaskTest();
URL url = null;
try {
url = new URL("http://www.baidu.com");
} catch (MalformedURLException e) {
e.printStackTrace();
}
async.execute(url,url);//这里传进去的数据是给doInBackground做参数用的,可以传任意个参数
}
}

AsyncTask中各个函数详细的调用过程,初步实现异步任务的更多相关文章

  1. php中session_id()函数详细介绍,会话id生成过程及session id长度

    php中session_id()函数原型及说明session_id()函数说明:stringsession_id([string$id])session_id() 可以用来获取/设置 当前会话 ID. ...

  2. Presto 标量函数注册和调用过程简述

    在Presto 函数开发一文中已经介绍过如何进行函数开发,本文主要讲述标量函数(Scalar Function)实现之后,是如何在Presto内部进行注册和被调用的.主要讲述标量函数是因为:三类函数的 ...

  3. 4.C++中的函数重载,C++调用C代码,new/delete关键字,namespace(命名空间)

    本章主要内容: 1)函数重载 2)C++调用C代码 3)new/delete关键字实现动态内存分配 4)namespace命名空间 大家都知道,在生活中,动词和不同的名词搭配一起,意义都会大有不同,比 ...

  4. linux中 probe函数的何时调用的?

    点击打开链接 linux中 probe函数何时调用的 所以的驱动教程上都说:只有设备和驱动的名字匹配,BUS就会调用驱动的probe函数,但是有时我们要看看probe函数里面到底做了什么,还有传递给p ...

  5. C++和C中的函数如何相互调用

    今天笔试遇到的一题,当时就写了在函数前声明为C,按C编译. 首先是在C中调用C++函数,包括普通函数,重载函数以及成员函数. 对于普通函数,在C++中声明为extern "C",在 ...

  6. MySQL中字符串函数详细介绍

    MySQL字符串函数对于针对字符串位置的操作,第一个位置被标记为1. ASCII(str)返回字符串str的 最左面字符的ASCII代码值.如果str是空字符串, 返回0.如果str是NULL,返回N ...

  7. armv8(aarch64)linux内核中flush_dcache_all函数详细分析【转】

    转自:http://blog.csdn.net/qianlong4526888/article/details/12062809 版权声明:本文为博主原创文章,未经博主允许不得转载. /* *  __ ...

  8. armv8(aarch64)linux内核中flush_dcache_all函数详细分析

    /* *  __flush_dcache_all() *  Flush the wholeD-cache. * Corrupted registers: x0-x7, x9-x11 */ ENTRY( ...

  9. GDB踪函数的完整调用过程 及原理

    http://www.lenky.info/archives/2013/02/2202 Breakpoint , .so. (gdb) bt # .so. # .so. # .so. # .so. # ...

随机推荐

  1. WebApi 接口参数详解

    WebApi 接口参数不再困惑:传参详解   阅读目录 一.get请求 1.基础类型参数 2.实体作为参数 3.数组作为参数 4.“怪异”的get请求 二.post请求 1.基础类型参数 2.实体作为 ...

  2. 【AtCoder】ARC090

    C - Candies 前一枚举一个i,求第一行的前i个和第二行从第n个到第i个 代码 #include <bits/stdc++.h> #define fi first #define ...

  3. maven中的各种问题

    [ERROR] Plugin org.apache.maven.plugins:maven-shade-plugin:3.1 or one of its dependencies could not ...

  4. shared_ptr(作为局部变量返回)

    智能指针:shared_ptr 1.一个局部的shared_ptr 作为返回值过程:当shared_ptr 被创建的时候,自身的引用计数 +1,当前引用计数为 1 , 按值返回以后 引用计数 + 1 ...

  5. Qt界面UI之QML初见(学习笔记四)

    拖了大半年,今天终于有更新了...我自己都不好意思,最近太忙了! 今天讲一下:QML语法 一 概述 QML是一种专门用于构建用户界面的编程语言,它允许用户构建高性能,具有流畅特效的可视化应用程序,QM ...

  6. Python之路,入门学习(一)

    一.变量\字符编码 声明变量 #_*_coding:utf-8_*_ name = "Alex Li" 上述代码声明了一个变量,变量名为: name,变量name的值为:" ...

  7. 网页图表Highcharts实践教程标之添加题副标题版权信息

    网页图表Highcharts实践教程标之添加题副标题版权信息 Highcharts辅助元素 辅助元素图表的非必要元素,如标题.版权信息.标签.载入动态.它们不和图表数据发生关联,只是额外说明一些基本信 ...

  8. 模拟赛T1 素数

    没有链接 描述: 给p,q,求a^2+b^2 = p*q解的个数,p,q是素数 沙雕打表结论题 然后怼了3h吼爆零 题解 首先这是个结论题 然后这是证明 代码 #include <stdio.h ...

  9. POJ.1379.Run Away(模拟退火)

    题目链接 POJ输出不能用%lf! mmp从4:30改到6:00,把4:30交的一改输出也过了. 于是就有了两份代码.. //392K 500MS //用两点构成的矩形更新,就不需要管边界了 #inc ...

  10. STL中优先队列的使用

    普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除.在优先队列中,元素被赋予优先级.当访问元素时,具有最高优先级的元素最先删除.优先队列具有最高级先出的行为特征.我们来说一下C++的 ...