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

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

题目1254:N皇后问题

题目1254:N皇后问题 时间限制:1 秒 内存限制:128 兆 特殊判题:否 题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上。因为皇后可以直走,横走和斜走如下图)。 你的任务是,对于给定的N,求出有多少种合法的放置方法。输出N皇后问题所有不同的摆放情况个数。 输入

vscode中文乱码问题,注释,终端,调试乱码一劳永逸版

忘记咋回事突然出现了乱码问题,很多方法都试了,注释乱码解决了,终端又乱码,调试窗口也乱码,最后经过本人不懈努力,终于全部解决了,现在分享给大家我的方法。 乱码的原因是各个地方用的编码格式不统一,所以把他们设成统一的utf8. 1.电脑的编码格式 开始-设置-时间和语言-语言和区域 管理语言设置-更改系统区域设置-勾选Bata版:使用utf8-确定-然后按指示重启 2.vscode

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR