javaweb学习总结二十三(servlet开发之线程安全问题)
一:servlet線程安全問題發(fā)生的條件
如果多個(gè)客戶端訪問同一個(gè)servlet時(shí),發(fā)生線程安全問題,那么它們?cè)L問的是相同的資源。如果訪問
的不是相同資源,則不存在線程安全問題。
實(shí)例1:不會(huì)產(chǎn)生線程安全問題,因?yàn)槊總€(gè)客戶端發(fā)送請(qǐng)求,都會(huì)創(chuàng)建一個(gè)線程,都會(huì)創(chuàng)建一個(gè)count
不存在資源共享的問題。
1 public void doPost(HttpServletRequest request, HttpServletResponse response) 2 throws ServletException, IOException { 3 int count = 0; 4 count++; 5 response.getOutputStream().write((count + "").getBytes()); 6 }?
實(shí)例2:這種方式,多個(gè)線程公用資源,應(yīng)該存在線程安全問題,但是我的測(cè)試結(jié)果一直不存在線程安全問題。有點(diǎn)不解?
1 public class ServletDemo extends HttpServlet {2 3 int count = 0;4 5 public void doGet(HttpServletRequest request, HttpServletResponse response)6 throws ServletException, IOException {7 count++;8 try { 9 Thread.sleep(1000 * 10); 10 } catch (InterruptedException e) { 11 e.printStackTrace(); 12 } 13 response.getOutputStream().write((count + "").getBytes()); 14 } 15 16 }?
二:線程安全問題的處理
1:對(duì)于線程安全問題最簡(jiǎn)單的方式就是加鎖:
將存在線程安全問題的代碼放到同步代碼塊中,這樣線程訪問時(shí)就需要排隊(duì)拿到鑰匙,只有上一個(gè)
線程訪問完畢,才會(huì)釋放掉鎖,先一個(gè)線程才可以進(jìn)入。但是存在明顯的缺點(diǎn):就是效率太低了。
例如:門戶網(wǎng)站日訪問量過千萬(wàn),效率太低了。
注意:應(yīng)該盡量減少代碼在同步代碼塊中
1 synchronized (this) { 2 count++; 3 try { 4 Thread.sleep(1000 * 10); 5 } catch (InterruptedException e) { 6 e.printStackTrace(); 7 } 8 response.getOutputStream().write((count + "").getBytes()); 9 }?
2:實(shí)現(xiàn)singleThreadModel接口
servlet實(shí)現(xiàn)singleThreadModel接口后,每個(gè)線程都會(huì)創(chuàng)建servlet實(shí)例,這樣每個(gè)客戶端請(qǐng)求就不存在共享資源的問題
,但是servlet響應(yīng)客戶端請(qǐng)求的效率太低,所以已經(jīng)淘汰。
轉(zhuǎn)載于:https://www.cnblogs.com/warrior4236/p/5991352.html
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的javaweb学习总结二十三(servlet开发之线程安全问题)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 刷题向》关于一道比较优秀的递推型DP(o
- 下一篇: Weblogic部署项目过程中的一些问题