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