自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

關(guān)于多任務(wù)下載問題

移動開發(fā) Android
近期項(xiàng)目中,遇到一個(gè)問題,列表數(shù)據(jù)中的圖片地址是一個(gè)需要下載JS再解析的字段,之前的圖片下載是一個(gè)異步的過程,由一個(gè)隊(duì)列處理。

Android系統(tǒng)以不同尋常的方式處理多個(gè)應(yīng)用程序的同時(shí)運(yùn)行。來自于其它不同平臺的開發(fā)者或許會對這樣的運(yùn)行機(jī)制感到很奇怪。而理解Android多任務(wù)的運(yùn)行,對于設(shè)計(jì)出可以良好運(yùn)行的應(yīng)用程序,以及與Android平臺的其它部分進(jìn)行無縫結(jié)合都具有重要意義。這篇文章說明了Android的多任務(wù)方式設(shè)計(jì)上的成因,它對應(yīng)用程序運(yùn)行產(chǎn)生的影響,還有你可以怎樣更好地利用Android的這一特性。

近期項(xiàng)目中,遇到一個(gè)問題,列表數(shù)據(jù)中的圖片地址是一個(gè)需要下載JS再解析的字段,之前的圖片下載是一個(gè)異步的過程,由一個(gè)隊(duì)列處理。

 

 

  1. public class ImageTaskExecutor { 
  2.  
  3.  
  4.     /** 存放任務(wù)的鏈表,first-in last-out */ 
  5.     private LinkedList<ImageTask> mTaskQueue = null
  6.  
  7.  
  8.     /** 執(zhí)行任務(wù)的線程 */ 
  9.     private ThreadUnit mThreadUnit = null
  10.      
  11.     /** 執(zhí)行任務(wù)的間隔時(shí)間 */ 
  12.     public static final long WAIT_PERIOD = 50L; 
  13.      
  14.     private volatile boolean paused; 
  15.     private final Object signal = new Object(); 
  16.      
  17.     /** 
  18.      * 添加新任務(wù) 
  19.      *  
  20.      * @param task 
  21.      * @return 是否添加成功 
  22.      */ 
  23.     public synchronized boolean addNewTask(final ImageTask task) { 
  24.         if (mThreadUnit == null) { 
  25.             mThreadUnit = new ThreadUnit(); 
  26.             mTaskQueue = new LinkedList<ImageTask>(); 
  27.             new Thread(mThreadUnit).start(); 
  28.         } 
  29.          
  30.         return mTaskQueue.offer(task); 
  31.     } 
  32.  
  33.  
  34.     class ThreadUnit implements Runnable { 
  35.  
  36.  
  37.         public boolean isRunning = false
  38.         private ImageTask task = null
  39.  
  40.  
  41.         @Override 
  42.         public void run() { 
  43.             try { 
  44.                 isRunning = true
  45.                 while (isRunning) { 
  46.                     while (mTaskQueue != null && mTaskQueue.isEmpty()) { 
  47.                         try { 
  48.                             Thread.sleep(WAIT_PERIOD); 
  49.                         } catch (InterruptedException e) { 
  50.                             e.printStackTrace(); 
  51.                         } 
  52.                     } 
  53.                     synchronized (signal) { 
  54.                         while (paused) { // pause point 
  55.                             signal.wait(); 
  56.                         } 
  57.                     } 
  58.                     if (mTaskQueue != null && !mTaskQueue.isEmpty()) { 
  59.                         task = mTaskQueue.removeFirst(); // 取出鏈表中的最后一個(gè)任務(wù) 
  60.                         if (task != null) { 
  61.                             task.execute(); 
  62.                         } 
  63.                     } 
  64.                 } // end while 
  65.             } catch (Exception e) { 
  66.                 e.toString(); 
  67.             } 
  68.         } // end run 
  69.     } 
  70.      
  71.     /** 
  72.      * 中斷任務(wù)的執(zhí)行 
  73.      */ 
  74.     public void pauseTaskThread() { 
  75.         setPaused(); 
  76.     } 
  77.      
  78.     private void setPaused() { 
  79.         synchronized (signal) { 
  80.             paused = true
  81.         } 
  82.     } 
  83.  
  84.  
  85.     private void setUnpaused() { 
  86.         synchronized (signal) { 
  87.             paused = false
  88.             signal.notify(); 
  89.         } 
  90.     } 
  91.      
  92.     /** 
  93.      * 恢復(fù)任務(wù)的執(zhí)行 
  94.      */ 
  95.     public void resumeTaskThread(){ 
  96.         setUnpaused(); 
  97.     } 
  98.      
  99.  
  100.  
  101.     /** 
  102.      * 終止任務(wù)的執(zhí)行 
  103.      */ 
  104.     public void terminateTaskThread() { 
  105.         if (mThreadUnit != null) { 
  106.             mThreadUnit.isRunning = false
  107.         } 
  108.         if (mTaskQueue != null) { 
  109.             mTaskQueue.clear(); 
  110.         } 
  111.         mThreadUnit = null
  112.         mTaskQueue = null
  113.     } 

 

現(xiàn)在列表中的圖片信息需要解析,如果再開一個(gè)隊(duì)列,頁面直接卡得不動了。。。

然后,這時(shí)候就考濾整個(gè)下載JS然后再下載圖片這個(gè)過程需要使用同步操作了

后來發(fā)現(xiàn),這個(gè)過程操作會比較長,頁面的開始出現(xiàn)第一項(xiàng)的圖片閃跳

原來adapter里面的getView 方法,被調(diào)用的過程中,contentview里面的內(nèi)容會被隨機(jī)復(fù)用,然后就。。。

  1. public void inflateTaobaoImage(final String jsonUrl, final View view, 
  2.             final int error_bg_Id) { 
  3.         if (jsonUrl == null || jsonUrl.equals("")) { 
  4.             return
  5.         } 
  6.  
  7.  
  8.         String imgUrl = getImgUrl(jsonUrl); 
  9.         if (!TextUtils.isEmpty(imgUrl)) { 
  10.             final String originJsonUrl = (String) view.getTag(IMG_TAG); 
  11.             if (TextUtils.equals(originJsonUrl, jsonUrl)) { 
  12.                 LogsPrinter.debugError(TAG, "inflateTaobaoImage in HashMap " 
  13.                         + originJsonUrl + " " + view); 
  14.                 inflateImage(imgUrl, view, error_bg_Id); 
  15.             } 
  16.         } else { 
  17.             mTaskExecutor.addNewTask(new ImageTask(jsonUrl) { 
  18.                 @Override 
  19.                 public void execute() { 
  20.                     String taobaoImgUrl = downloadUrlString(jsonUrl 
  21.                             + "&callback=success_jsonpCallback"); 
  22.  
  23.  
  24.                     final String imgUrl = getTaobaoImageUrl(taobaoImgUrl); 
  25.                     LogsPrinter.debugError("add map", imgUrl + " " + jsonUrl); 
  26.                     taobaoImgMap.add(imgUrl, jsonUrl); 
  27.  
  28.  
  29.                     final String originJsonUrl = (String) view.getTag(IMG_TAG); 
  30.                     if (TextUtils.equals(originJsonUrl, jsonUrl)) { 
  31.                         baseHandlers.post(new Runnable() { 
  32.  
  33.  
  34.                             @Override 
  35.                             public void run() { 
  36.                                 inflateImage(imgUrl, view, error_bg_Id); 
  37.                             } 
  38.                         }); 
  39.                     } 
  40.                 } 
  41.             }); 
  42.         } 
  43.     } 

值得注意的一個(gè)問題是:

settag的值需要是一個(gè)固定的值。不然,有時(shí)候會出現(xiàn)加載多次的情況。。

責(zé)任編輯:張葉青 來源: 安卓巴士
相關(guān)推薦

2011-05-31 13:29:40

Android 多線程

2012-05-18 13:26:11

HTC

2010-02-26 17:47:07

2014-05-09 12:59:26

iOS移動互聯(lián)網(wǎng)

2011-07-18 14:23:40

iPhone 多任務(wù)

2022-09-28 15:34:06

機(jī)器學(xué)習(xí)語音識別Pytorch

2015-06-17 10:41:50

2021-10-13 09:33:26

Python 多任務(wù)進(jìn)程

2023-11-07 18:56:05

2023-11-07 07:13:31

推薦系統(tǒng)多任務(wù)學(xué)習(xí)

2010-10-29 09:01:01

Windows Pho

2013-12-12 16:44:25

Lua協(xié)程

2009-07-17 17:29:13

多任務(wù)多線程

2024-04-03 07:56:50

推薦系統(tǒng)多任務(wù)推薦

2023-07-07 12:30:00

模型技術(shù)

2023-11-29 07:25:58

2012-07-13 13:42:40

2009-07-02 13:29:38

JSP技術(shù)

2014-06-18 10:41:31

Android多任務(wù)機(jī)制

2015-07-14 16:15:22

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號