国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Android下,rxJava+retrofit 并發上傳文件和串行上傳文件的效率為什么差不多?

瀏覽:126日期:2024-02-28 16:07:55

問題描述

有個功能需要同時上傳N個文件。代碼如下:

ApiService as = ApiManager.getApiService(); final ExecutorService es = Executors.newFixedThreadPool(9);final int count = Bimp.tempSelectBitmap.size();final CountDownLatch finishedLatch = new CountDownLatch(count);final long start = System.currentTimeMillis();for (int k = 0; k < count; k++) { final String fp = Bimp.tempSelectBitmap.get(k).getImagePath(); RequestBody fbody = RequestBody.create(MediaType.parse('image/*'), new File(fp)); as.uploadAttach(fbody) .subscribeOn(Schedulers.from(es)) .observeOn(Schedulers.computation()) .subscribe(new Subscriber<UploadAttachJSON>() {@Overridepublic void onCompleted() {}@Overridepublic void onError(Throwable e) { finishedLatch.countDown(); Log.e('UPLOAD FAILED -------->', fp);}@Overridepublic void onNext(UploadAttachJSON uploadAttachJSON) { finishedLatch.countDown(); sb.append(uploadAttachJSON.url).append(','); Log.e('UPLOADED IMAGE URL -->', uploadAttachJSON.url); h.post(new Runnable() {@Overridepublic void run() { pd.setMessage('正在上傳... ' + (count - finishedLatch.getCount()) + '/' + count);} });} });}try { finishedLatch.await();} catch (InterruptedException e) { e.printStackTrace();}long end = System.currentTimeMillis();Log.e('IMAGE UPLOAD COMPLETED', (end - start) + '');es.shutdown();

以上為并行的寫法。從線程池中拿出N個線程來同時上傳這N個文件。

串行寫法: .subscribeOn(Schedulers.io()) 或者 用Observable.merge來合并這些請求。

結果發現并行和串行所花費的時間幾乎都差不多。。 是不是和android底層有關?這些網絡請求其實最后都被底層給block了,然后串行出去?

問題解答

回答1:

設備的網速是不是有限制

回答2:

有很多因素需要考慮1.自己的代碼實現2.設備底層的傳輸實現3.服務器接收數據的代碼實現

任何一個部分不是并發的,最后的結果就不是并發的

標簽: java
相關文章:
主站蜘蛛池模板: 红桥区| 广元市| 淳化县| 福海县| 威宁| 阿巴嘎旗| 德清县| 德保县| 清镇市| 锦州市| 道真| 蓬安县| 东乌珠穆沁旗| 安陆市| 平阳县| 青铜峡市| 潮安县| 和静县| 谷城县| 略阳县| 黄浦区| 安康市| 宜宾市| 昌吉市| 囊谦县| 宜黄县| 湖北省| 抚远县| 呼伦贝尔市| 山阳县| 乐业县| 高雄县| 崇信县| 辽阳市| 三亚市| 尚志市| 漯河市| 门源| 六安市| 武城县| 新闻|