<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                ### 一、使用場景 在負責后臺開發的時候,很多時候都是提供接口給前端開發人員去調用,會遇到這樣的場景: 需要提供一個領獎接口,每個用戶名只能領取一次,我們可以將成功領取的用戶在數據庫用個標記保存起來。如果這個用戶再來領取的時候,查詢數據庫看該用戶是否領取過。 但是問題來了,假設用戶手速很快,極短時間內點了兩次領獎按鈕(前端沒有進行控制,我們也不能依賴前端去控制)。那么可能掉了兩次領獎接口,而且有可能第二次調用的時候查詢數據庫的時候,第一次領獎還沒有執行完成更新領獎標記。 這種場景就可以使用到synchronized ### 二、使用實例 代碼: ~~~ package com.luo.test; public class SynTest { public static void main(String args[]) throws InterruptedException{ SynTest synTest = new SynTest(); synTest.test(); } public void test() throws InterruptedException{ new SynThread1().start(); new SynThread1().start(); } public void syn(String userName) throws Exception { synchronized(userName) { System.out.println("進入到同步塊,userName=" + userName); Thread.sleep(5000); //5秒 System.out.println("退出同步塊,userName=" + userName); } } class SynThread1 extends Thread { public void run(){ try { syn("luoguohui"); } catch (Exception e) { e.printStackTrace(); } } } } ~~~ 運行結果: ![這里寫圖片描述](https://box.kancloud.cn/2016-03-15_56e77db3e06d4.jpg "") 從結果來看,可知道,synchronized起作用了,這里調用了兩次syn(String userName)方法,期間設置其停留5秒,但是還是等第一次執行完,第二次調用才進入synchronized塊里面的。 為了進一步確認我們的假設,我們不防把synchronized去掉如下: ~~~ public void syn(String userName) throws Exception { // synchronized(userName) { System.out.println("進入到同步塊,userName=" + userName); Thread.sleep(5000); //5秒 System.out.println("退出同步塊,userName=" + userName); // } } ~~~ 運行結果: ![這里寫圖片描述](https://box.kancloud.cn/2016-03-15_56e77db408f45.jpg "") 對比即可分析出來了 使用方式從實例可看出來: ~~~ public void syn(String userName) throws Exception { synchronized(userName) { System.out.println("進入到同步塊,userName=" + userName); Thread.sleep(5000); //5秒 System.out.println("退出同步塊,userName=" + userName); } } ~~~ 用synchronized把代碼括起來。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看