AsyncTask onPostExecute 未执行问题

2024-06-01 15:38

本文主要是介绍AsyncTask onPostExecute 未执行问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在android4.0以下设备上onPostExecute不执行,doInBackground也无抛出异常。

在android4.2以上设备上onPostExecute是执行的,没问题。

那么问题就来了,一路查寻,牵扯出好多问题。

以下是我个人遇到的情况,新建个测试AsyncTask项目没有问题,但是在原项目下问题就来了。

AndroidManifest.xml里加入了android:launchMode="singleTask"

得在UI线程里调用execute;在onCreate中调用,onPostExecute是不执行的。


android-support-v4.jar低版本下,在FragmentActivity下调用,onPostExecute是不执行的。


关键在MAINActivity onCreate中添加

try {

Class.forName("android.os.AsyncTask");

} catch (ClassNotFoundException e) {

e.printStackTrace();

}


以下是案例,有关HTTP请求,需要加入gson.jar

package com.example.asynctasktest;import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.view.View.OnClickListener;public class MainActivity extends Activity {private Button button;  private ProgressBar progressBar;  private TextView textView;  @Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);button = (Button)findViewById(R.id.button03);  progressBar = (ProgressBar)findViewById(R.id.progressBar02);  textView = (TextView)findViewById(R.id.textView01);  button.setOnClickListener(new OnClickListener() {  @Override  public void onClick(View v) {  startGetArea();}  });  ProgressBarAsyncTask asyncTask = new ProgressBarAsyncTask(textView, progressBar);  asyncTask.execute("http://www.xxx.com/getAreaList.htm");}public void startGetArea(){Message msg = mhandler.obtainMessage();msg.what = 1;mhandler.sendMessage(msg);}/*** handler处理消息机制*/protected Handler mhandler = new Handler() {public void handleMessage(Message message) {switch (message.what) {case 1:new ProgressBarAsyncTask(textView, progressBar).execute("http://www.xxx.com/getAreaList.htm");break;}}};@Overridepublic boolean onCreateOptionsMenu(Menu menu) {// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.main, menu);return true;}}


package com.example.asynctasktest;import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.List;import org.apache.http.HttpEntity;
import org.apache.http.util.EntityUtils;import android.os.AsyncTask;  
import android.util.Log;
import android.widget.ProgressBar;  
import android.widget.TextView;import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.reflect.TypeToken;/**  * 生成该类的对象,并调用execute方法之后  * 首先执行的是onProExecute方法  * 其次执行doInBackgroup方法  *  */  
public class ProgressBarAsyncTask extends AsyncTask<String, Integer, List<AllArea>> {  private TextView textView;  private ProgressBar progressBar;  private static Gson gson = new GsonBuilder().setVersion(1).create();List<String> listnames = new ArrayList<String>();List<String> listid = new ArrayList<String>();public ProgressBarAsyncTask(TextView textView, ProgressBar progressBar) {  super();  this.textView = textView;  this.progressBar = progressBar;  }  /**  * 这里的String参数对应AsyncTask中的第一个参数   * 这里的List<AllArea>返回值对应AsyncTask的第三个参数  * 该方法并不运行在UI线程当中,主要用于异步操作,所有在该方法中不能对UI当中的空间进行设置和修改  * 但是可以调用publishProgress方法触发onProgressUpdate对UI进行操作  */@Overrideprotected List<AllArea> doInBackground(String... params) {// TODO Auto-generated method stubList<AllArea> areaList = null;HttpEntity entity;try {entity = HttpUtil.send(HttpUtil.METHOD_GET, params[0], null);String json=EntityUtils.toString(entity);Type type = new TypeToken<List<AllArea>>() {}.getType();areaList = gson.fromJson(json, type);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}return areaList;}/**  * 这里的String参数对应AsyncTask中的第三个参数(也就是接收doInBackground的返回值)  * 在doInBackground方法执行结束之后在运行,并且运行在UI线程当中 可以对UI空间进行设置  */  @Overrideprotected void onPostExecute(List<AllArea> result) {// TODO Auto-generated method stubsuper.onPostExecute(result);textView.setText("异步操作执行结束" + result);if(result == null){Log.e("", "result == null");}else{Log.e("", "result != null"+result.size());for(int i = 0;i<result.size();i++){listnames.add(result.get(i).getIndustryName());listid.add(result.get(i).getId()+"");}}}/*** 该方法运行在UI线程当中,并且运行在UI线程当中 可以对UI空间进行设置 */@Override  protected void onPreExecute() {  textView.setText("开始执行异步线程");  }  /**  * 这里的Intege参数对应AsyncTask中的第二个参数  * 在doInBackground方法当中,,每次调用publishProgress方法都会触发onProgressUpdate执行  * onProgressUpdate是在UI线程中执行,所有可以对UI空间进行操作  */  @Override  protected void onProgressUpdate(Integer... values) {  int vlaue = values[0];  progressBar.setProgress(vlaue);  } 
}  


package com.example.asynctasktest;import java.util.ArrayList;import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;import android.util.Log;/***	HTTP请求方式类* @author Administrator**/
public class HttpUtil {public static final int METHOD_GET=0;public static final int METHOD_POST=1;/*** * @param method GET请求* @param url 请求路径* @param pairs 提交参数* @return* @throws Exception*/public static HttpEntity send(int method,String url,ArrayList<NameValuePair> pairs)throws Exception{HttpClient client=new DefaultHttpClient();HttpResponse resp=null;switch(method){case METHOD_GET:Log.i("send", url);HttpGet get=new HttpGet(url);resp=client.execute(get);Log.i("send", resp.toString());break;case METHOD_POST:HttpPost post=new HttpPost(url);HttpEntity entity=new UrlEncodedFormEntity(pairs,"utf-8");post.setEntity(entity);post.setHeader("Content-Type", "x-www-form-urlencoded");resp=client.execute(post);break;}return resp.getEntity();}
}

package com.example.asynctasktest;import java.io.Serializable;public class AllArea implements Serializable{/*** */private static final long serialVersionUID = -8325422695071123262L;private int id;private int type;private int parentId;private String areaName;private String areaNo;public int getId() {return id;}public void setId(int id) {this.id = id;}public int getType() {return type;}public void setType(int type) {this.type = type;}public int getParentId() {return parentId;}public void setParentId(int parentId) {this.parentId = parentId;}public String getIndustryName() {return areaName;}public void setIndustryName(String industryName) {this.areaName = industryName;}public String getIndustryDesc() {return areaNo;}public void setIndustryDesc(String industryDesc) {this.areaNo = industryDesc;}}

[{"state":1,"type":1,"seq":1,"parentId":1,"areaNo":"3601","areaName”:”东城区”,”id”:11},{“state":1,"type":1,"seq":2,"parentId":1,"areaNo":"3602","areaName”:”西城区”,”id”:22},{“state":1,"type":1,"seq":3,"parentId":1,"areaNo":"3603","areaName”:”海淀区”,”id”:33},{“state":1,"type":1,"seq":4,"parentId":1,"areaNo":"3604","areaName”:”朝阳区”,”id”:44},{“state":1,"type":1,"seq":5,"parentId":1,"areaNo":"3605","areaName”:”昌平区”,”id”:55},{“state":1,"type":1,"seq":6,"parentId":1,"areaNo":"3606","areaName”:”丰台区”,”id”:66}]


这篇关于AsyncTask onPostExecute 未执行问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模