记录: 开发中的2个线程的使用问题
長(zhǎng)時(shí)間任務(wù)導(dǎo)致parser線程阻塞的一個(gè)問題
在一個(gè)網(wǎng)絡(luò)程序中,有一個(gè)網(wǎng)絡(luò)數(shù)據(jù)緩沖池,所有網(wǎng)絡(luò)進(jìn)來的數(shù)據(jù)會(huì)先放到緩沖池中。然后又Parser線程來進(jìn)行解包,粘包處理,得到的數(shù)據(jù)包解析后,執(zhí)行相應(yīng)的操作。
其中有個(gè)操作,會(huì)執(zhí)行very long 的時(shí)間,此時(shí)就會(huì)導(dǎo)致parser線程阻塞住,線程狀態(tài)變成了ThreadState.WaitSleepJoin.
而且由于時(shí)間過去稍長(zhǎng),一下子還不知是啥問題。
經(jīng)過檢查,才發(fā)現(xiàn)是后期添加的一個(gè)處理,直接調(diào)用的操作會(huì)耗費(fèi)很長(zhǎng)時(shí)間。
現(xiàn)在就好解決了,讓長(zhǎng)時(shí)間的耗時(shí)操作放在一個(gè)線程中進(jìn)行處理,問題解決。
線程池中線程執(zhí)行時(shí)機(jī)
開發(fā)團(tuán)隊(duì)中,使用一個(gè)線程池,其中的線程處理任務(wù)完成的處理。客戶端在處理任務(wù)完成時(shí),會(huì)執(zhí)行2個(gè)操作,一個(gè)是上報(bào)完成,一個(gè)再接著請(qǐng)求下個(gè)操作。但是由于完成操作使用了線程池的線程來處理完成操作。有個(gè)弟兄想當(dāng)然地認(rèn)為這個(gè)操作會(huì)立即完成。沒有同步這些線程操作– 結(jié)果導(dǎo)致一個(gè)隨機(jī)問題,給查找問題帶來極大的困難了–任務(wù)在后面的請(qǐng)求操作處理后,完成任務(wù)的線程才執(zhí)行。導(dǎo)致后面的邏輯錯(cuò)誤。
總結(jié)
以上是生活随笔為你收集整理的记录: 开发中的2个线程的使用问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Lua语法简介
- 下一篇: CSharp中的数组和ArrayList