android異步請求服務器數(shù)據(jù)示例
1、在android4.0以后的版本,主線程(UI線程)不在支持網(wǎng)絡請求,原因大概是影響主線程,速度太慢,容易卡機,所以需要開啟新的線程請求數(shù)據(jù);
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
2、新線程完成后一啟動,發(fā)現(xiàn)報錯,空指針 nullpointerexception,要等待線程完畢后才能得到數(shù)據(jù),下面是兩種解決方法:
1)要么判斷線程是否還活著;
2)要么在線程中設置一flag,結束后,更改其狀態(tài)
/*
//等待線程thread1執(zhí)行完畢
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();
}}}
3、處理返回的json數(shù)據(jù)
1)向服務器請求Json數(shù)據(jù),保存在carList
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());
2)解析Json數(shù)據(jù)
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();
}
4、圖片加載通常很慢,最好異步請求
異步請求類源代碼
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;
public class AsyncViewTask extends AsyncTask {
private View mView;
private HashMap> imageCache;
public AsyncViewTask() {
imageCache = new HashMap>();
}
protected Drawable doInBackground(View... views) {
Drawable drawable = null;
View view = views[0];
if (view.getTag() != null) {
if (imageCache.containsKey(view.getTag())) {
SoftReference cache = imageCache.get(view.getTag().toString());
drawable = cache.get();
if (drawable != null) {
return drawable;
}
}
try {
if (URLUtil.isHttpUrl(view.getTag().toString())) {// 如果為網(wǎng)絡地址。則連接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 {// 如果為本地數(shù)據(jù),直接解析
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;
}}}
- Android異步消息機制詳解
- android開發(fā)教程之handle實現(xiàn)多線程和異步處理
- Android中BroadcastReceiver(異步接收廣播Intent)的使用
- Android多線程及異步處理問題詳細探討
- Android加載對話框同時異步執(zhí)行實現(xiàn)方法
- android開發(fā)教程之handler異步更新ui
- Android App中實現(xiàn)圖片異步加載的實例分享
- 詳解Android的OkHttp包編寫異步HTTP請求調用的方法
- Android最基本的異步網(wǎng)絡請求框架
- 全面總結Android中線程的異步處理方式
- Android編程實現(xiàn)異步消息處理機制的幾種方法總結
相關文章
Android貝塞爾曲線實現(xiàn)填充不規(guī)則圖形并隨手指運動
這篇文章主要為大家詳細介紹了Android貝塞爾曲線實現(xiàn)填充不規(guī)則圖形,并隨手指運動,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09android: targetSdkVersion升級中Only fullscreen activities can r
這篇文章主要給大家介紹了關于Android target SDK和build tool版本升級中遇到Only fullscreen activities can request orientation問題的解決方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2018-09-09Android使用Profiler查看應用內存分析的操作步驟
內存分析是Profiler中的一個組件,可以幫助我們識別可能會導致應用卡頓、凍結甚至崩潰的內存泄露和內存抖動,本文小編將給大家介紹一下Android使用Profiler查看應用內存分析的操作步驟,需要的朋友可以參考下2023-10-10iOS開發(fā)中TableView類似QQ分組的折疊與展開效果
這篇文章主要介紹了iOS開發(fā)中TableView類似QQ分組的折疊與展開效果,其實要做這個效果我先想到的是在tableView中再嵌套多個tableView。下面通過本文給大家分享實現(xiàn)思路,需要的朋友可以參考下2016-12-12