android异步向服务器请求数据
下面就android向服务器请求数据的问题分析如下:
1、在android4.0以后的版本,主线程(UI线程)不在支持网络请求,原因大概是影响主线程,速度太慢,容易卡机,所以需要开启新的线程请求数据;
- <span style="font-family:System;font-size:12px;">thread1 = new Thread(){
- @Override
- public void run() {
- try {
- URL url = new URL(WebUrlManager.CARSEVER_GetCarsServlet);
- HttpURLConnection conn = (HttpURLConnection) url.openConnection();
- BufferedInputStream bis = new BufferedInputStream(conn.getInputStream());
- //缓冲读取
- byte[] data = new byte[1024];
- int len = 0;
- String bufferString = "";
- while((len = bis.read(data)) != -1){
- bufferString+=new String(data, 0, len);
- }
- carList = new JSONArray(bufferString.trim());
- //System.out.println(carList);
- /*
- for(int i=0;i<carList.length();i++){
- System.out.println("加载图片");
- JSONObject json = (JSONObject) carList.get(i);
- String imageName = json.getString("image");
- bm = BitmapFactory.decodeStream(new URL(WebUrlManager.CARSERVER_CAR_IMAGE+imageName).openStream());
- carImageArray.add(bm);
- }
- */
- } catch (MalformedURLException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (JSONException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- flag = true;
- }
- };
- thread1.start();</span>
2、新线程完成后一启动,发现报错,空指针nullpointerexception,要等待线程完毕后才能得到数据,下面是两种解决方法:
1)要么判断线程是否还活着;
2)要么在线程中设置一flag,结束后,更改其状态
- <span style="font-family:System;font-size:12px;">/*
- //等待线程thread1执行完毕
- while(true){
- if(thread1.isAlive()){
- try {
- Thread.sleep(500);
- } catch (InterruptedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }else{
- break;
- }
- }
- */
- //当线程还没结束,就睡500毫秒ms
- while(!flag){
- try {
- Thread.sleep(500);
- } catch (InterruptedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- }</span>
3、处理返回的json数据
1)向服务器请求Json数据,保存在carList
- <span style="font-family:System;font-size:12px;">URL url = new URL(WebUrlManager.CARSEVER_GetCarsServlet);
- HttpURLConnection conn = (HttpURLConnection) url.openConnection();
- BufferedInputStream bis = new BufferedInputStream(conn.getInputStream());
- //缓冲读取
- byte[] data = new byte[1024];
- int len = 0;
- String bufferString = "";
- while((len = bis.read(data)) != -1){
- bufferString+=new String(data, 0, len);
- }
- carList = new JSONArray(bufferString.trim());</span>
2)解析Json数据
- <span style="font-family:System;font-size:12px;">JSONObject car = (JSONObject) getItem(position);
- try {
- //this.pic.setImageBitmap(carImageArray.get(position));
- this.title.setText(car.getString("title"));
- this.describe.setText(car.getString("describe"));
- this.updateTime.setText(car.getString("updateTime"));
- this.price.setText(String.format("%.1f", car.getDouble("price"))+"万");
- this.pic.setTag(WebUrlManager.CARSERVER_CAR_IMAGE+car.getString("image"));
- new AsyncViewTask().execute(this.pic);
- } catch (JSONException e1) {
- e1.printStackTrace();
- }</span>
4、图片加载通常很慢,最好异步请求
1)先贴出异步请求的类源代码
- <span style="font-family:System;font-size:12px;">import java.io.InputStream;
- import java.lang.ref.SoftReference;
- import java.net.HttpURLConnection;
- import java.net.URL;
- import java.util.HashMap;
- import android.graphics.drawable.Drawable;
- import android.os.AsyncTask;
- import android.util.Log;
- import android.view.View;
- import android.webkit.URLUtil;
- import android.widget.ImageView;
- /**
- * @author wzy qq:290581825 http://blog.csdn.net/wzygis
- */
- public class AsyncViewTask extends AsyncTask<View, Void, Drawable> {
- private View mView;
- private HashMap<String, SoftReference<Drawable>> imageCache;
- public AsyncViewTask() {
- imageCache = new HashMap<String, SoftReference<Drawable>>();
- }
- protected Drawable doInBackground(View... views) {
- Drawable drawable = null;
- View view = views[0];
- if (view.getTag() != null) {
- if (imageCache.containsKey(view.getTag())) {
- SoftReference<Drawable> cache = imageCache.get(view.getTag().toString());
- drawable = cache.get();
- if (drawable != null) {
- return drawable;
- }
- }
- try {
- if (URLUtil.isHttpUrl(view.getTag().toString())) {// 如果为网络地址。则连接url下载图片
- URL url = new URL(view.getTag().toString());
- HttpURLConnection conn = (HttpURLConnection) url.openConnection();
- conn.setDoInput(true);
- conn.connect();
- InputStream stream = conn.getInputStream();
- drawable = Drawable.createFromStream(stream, "src");
- stream.close();
- } else {// 如果为本地数据,直接解析
- drawable = Drawable.createFromPath(view.getTag().toString());
- }
- } catch (Exception e) {
- Log.v("img", e.getMessage());
- return null;
- }
- }
- this.mView = view;
- return drawable;
- }
- protected void onPostExecute(Drawable drawable) {
- if (drawable != null) {
- ImageView view = (ImageView) this.mView;
- view.setImageDrawable(drawable);
- this.mView = null;
- }
- }
- }</span>
结果如下:
android异步向服务器请求数据的更多相关文章
- Java服务器对外提供接口以及Android端向服务器请求数据
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/5056780.html 讲解下java服务器是如何对移动终端提供接口的,以什么数据格式提供出去,移动端又是怎么 ...
- jqGrid怎么设置初始化页面时不加载数据(不向服务器请求数据)
最近做一些表格一直用到jqGrid,今天遇到一个问题: 1.就是页面加载的时候数据不显示,点击搜索才根据请求从服务器返回并显示内容. 2.默认不从服务器请求数据(不然在开发者工具下会显示请求不到数据的 ...
- 前端向服务器请求数据并渲染的方式(ajax/jQuery/axios/vue)
原理: jQuery的ajax请求:complete函数一般无论服务器有无数据返回都会显示(成功或者失败都显示数据): return result
- React学习(4)——向服务器请求数据并显示
本文中涉及到的技术包括:node.js/express服务器的搭建.fetch发送数据请求. 在之前的几篇文章中,介绍了如何搭建基础的React项目,以及一些简单知识,现在,我们还需要掌握如何用Rea ...
- COMET探索系列三【异步通知服务器关闭数据连接实现思路】
在小编络络 COMET实践笔记一文中注意事项中有这么一段话 使用长连接时, 存在一个很常见的场景:客户端需要关闭页 面,而服务器端还处在读取数据的阻塞状态,客户端需要及时通知服务器端关闭数据连接.服务 ...
- Ajax的get请求向服务器请求数据五步骤?
如下: ①创建ajax对象 ②建立http请求 ③发送http请求 ④设置ajax对象状态改变的回调函数 ⑤判断ajax状态是否等于4,做相应的业务逻辑
- jQuery基础(Ajax,load(),getJSON(),getScript(),post(),ajax(),同步/异步请求数据)
1.使用load()方法异步请求数据 使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为: load(url,[data],[callba ...
- 前端缓存API请求数据
1. 背景 在一些项目中,有时候会出现不同模块重复请求大量相同api接口的情况,特别是在一些功能相似的后台管理页面中.以下面这几个页面为例,每次进入页面都需要请求等大量重复的下拉框数据,下拉框数据短时 ...
- Android之三种网络请求解析数据(最佳案例)
AsyncTask解析数据 AsyncTask主要用来更新UI线程,比较耗时的操作可以在AsyncTask中使用. AsyncTask是个抽象类,使用时需要继承这个类,然后调用execute()方法. ...
随机推荐
- .NET中JSON序列化(数据集转JSON)
Json序列化和反序列化指的是:对象序列化为JSON,并可用于从 JSON 反序列化对象 在.net 3.5中已支持JSON,引用命名空间: using System.Web.Script.Seria ...
- python全栈开发day49-jquery的位置信息、事件流、事件对象,事件委托,事件绑定和解绑
一.昨日内容回顾 1. jQuery的属性操作 1) html属性操作:attr 2) DOM属性操作:prop 3) 类样式操作:addClass.removeClass.toggleClas ...
- 使用numpy产生随机数
numpy中的random模块包含了很多方法可以用来产生随机数,这篇文章将对random中的一些常用方法做一个总结. 1.numpy.random.rand(d0, d1, ..., dn) 作用:产 ...
- PHP函数之array_chunk
有时候需要对数组进行按分页处理,之前的做法是计算出数组大小,按分页计算出偏移量,再从起始偏移量处开始遍历页大小个数据.现在不用这么麻烦了,原来PHP函数里有个现成的函数array_chunk可以配合我 ...
- python命令行解析模块--argparse
python命令行解析模块--argparse 目录 简介 详解ArgumentParser方法 详解add_argument方法 参考文档: https://www.jianshu.com/p/aa ...
- canvas三角函数模拟水波效果
.katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...
- vue-particles粒子动画效果
1.安装vue-particles依赖包 npm install vue-particles --save-dev 2.在main.js文件中引入并使用 import Vue from 'vue' i ...
- {}+[]与console.log({}+[])结果不同?从JavaScript的大括号谈起
看到这样一个问题:为什么直接在控制台运行{} + []和用console.log({} + [])输出,两者结果不一样? 于是乎打开chrome的控制台运行了一下: 为什么结果会这样呢?不得已学习一下 ...
- nagle算法和TCP_NODELAY
写socket发现的一个诡异现象,当时将多个小数据写操作合并成一个写操作,问题就没了.Chenshuo同学还建议我设置TCP_NODELAY,只是后来因为事情忙,也就没有再深究下去. 现在大概明白,是 ...
- ZwQuerySystemInformation枚举内核模块及简单应用
简单说,即调用第11号功能,枚举一下内核中已加载的模块.部分代码如下://功能号为11,先获取所需的缓冲区大小ZwQuerySystemInformation(SystemModuleInformat ...