1钥星、問(wèn)題描述
這幾天測(cè)試重構(gòu)后的下載框架述召,發(fā)現(xiàn)在下載過(guò)程中如果網(wǎng)絡(luò)中斷或網(wǎng)絡(luò)較差蒲跨,個(gè)別應(yīng)用的下載就會(huì)阻塞卡住译断,一直卡在 “正在下載 xx%”。
2财骨、問(wèn)題排查和定位
思考:網(wǎng)絡(luò)差不應(yīng)該報(bào)網(wǎng)絡(luò)異常的錯(cuò)誤或者直接拋timeout異常嗎镐作?所以馬上去檢查Http請(qǐng)求的地方:發(fā)現(xiàn)在DownloadThread中使用HttpURLConnection進(jìn)行網(wǎng)絡(luò)請(qǐng)求時(shí)只是設(shè)置了connectTimeout,這樣在建立連接的時(shí)候如果網(wǎng)絡(luò)中斷隆箩,那么超時(shí)以后就會(huì)報(bào)出錯(cuò)誤该贾,這里是沒(méi)有問(wèn)題的。會(huì)不會(huì)是還少設(shè)置了其他參數(shù)的原因呢捌臊?
于是趕緊去查閱資料:
ConnectTimeout只有在網(wǎng)絡(luò)正常的情況下才有效杨蛋,而當(dāng)網(wǎng)絡(luò)不正常時(shí),ReadTimeout才真正的起作用,即IdIOHandlerStack 里的 WaitFor 是受ReadTimeout限制的逞力,因此曙寡,這2個(gè)屬性應(yīng)該結(jié)合實(shí)用。
connect timeout 是建立連接的超時(shí)時(shí)間寇荧;
read timeout举庶,是傳遞數(shù)據(jù)的超時(shí)時(shí)間。
正確的方法應(yīng)當(dāng)是調(diào)用HttpURLConnection的時(shí)候同時(shí)設(shè)置這兩個(gè)超時(shí)時(shí)間揩抡。
一看代碼户侥,果然漏了setReadTimeout。峦嗤。蕊唐。。烁设。OMG 替梨。。装黑。
3副瀑、解決方案
同時(shí)設(shè)置這兩個(gè)超時(shí)時(shí)間:
HttpURLConnection urlCon = (HttpURLConnection)url.openConnection();
urlCon.setConnectTimeout(20*1000);
urlCon.setReadTimeout(20*1000);