<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>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                ? ?在進行網絡編程時,我們常常見到同步(Sync)/異步(Async),阻塞(Block)/非阻塞(Unblock)四種調用方式: **同步:** ??????所謂同步,就是在發出一個功能調用時,在沒有得到結果之前,該調用就不返回。**也就是必須一件一件事做**,等前一件做完了才能做下一件事。 例如普通B/S模式(同步):提交請求\->等待服務器處理\->處理完畢返回?這個期間客戶端瀏覽器不能干任何事 **異步:** ??????異步的概念和同步相對。當一個異步過程調用發出后,調用者不能立刻得到結果。實際處理這個調用的部件在完成后,通過狀態、通知和回調來通知調用者。 例如 ajax請求(異步):?請求通過事件觸發\->服務器處理(這是瀏覽器仍然可以作其他事情)\->處理完畢 **阻塞** ?????阻塞調用是指調用結果返回之前,當前線程會被掛起(線程進入非可執行狀態,在這個狀態下,cpu不會給線程分配時間片,即線程暫停運行)。函數只有在得到結果之后才會返回。 ? ? ?有人也許會把阻塞調用和同步調用等同起來,實際上他是不同的。對于同步調用來說,很多時候當前線程還是激活的,只是從邏輯上當前函數沒有返回而已。?例如,我們在socket中調用recv函數,如果緩沖區中沒有數據,這個函數就會一直等待,直到有數據才返回。而此時,當前線程還會繼續處理各種各樣的消息。 **非阻塞** ??????非阻塞和阻塞的概念相對應,指在不能立刻得到結果之前,該函數不會阻塞當前線程,而會立刻返回。 對象的阻塞模式和阻塞函數調用 對象是否處于阻塞模式和函數是不是阻塞調用有很強的相關性,但是并不是一一對應的。阻塞對象上可以有非阻塞的調用方式,我們可以通過一定的API去輪詢狀?態,在適當的時候調用阻塞函數,就可以避免阻塞。而對于非阻塞對象,調用特殊的函數也可以進入阻塞調用。函數select就是這樣的一個例子。 1\. 同步,就是我調用一個功能,該功能沒有結束前,我死等結果。 2\. 異步,就是我調用一個功能,不需要知道該功能結果,該功能有結果后通知我(回調通知) 3\. 阻塞, ? ? ?就是調用我(函數),我(函數)沒有接收完數據或者沒有得到結果之前,我不會返回。 4\. 非阻塞, ?就是調用我(函數),我(函數)立即返回,通過select通知調用者 同步IO和異步IO的區別就在于:數據拷貝的時候進程是否阻塞! 阻塞IO和非阻塞IO的區別就在于:應用程序的調用是否立即返回! 對于舉個簡單c/s 模式: 同步:提交請求->等待服務器處理->處理完畢返回這個期間客戶端瀏覽器不能干任何事 異步:請求通過事件觸發->服務器處理(這是瀏覽器仍然可以作其他事情)->處理完畢 同步和異步都只針對于本機SOCKET而言的。 同步和異步,阻塞和非阻塞,有些混用,其實它們完全不是一回事,而且它們修飾的對象也不相同。 阻塞和非阻塞是指當進程訪問的數據如果尚未就緒,進程是否需要等待,簡單說這相當于函數內部的實現區別,也就是未就緒時是直接返回還是等待就緒; 而同步和異步是指訪問數據的機制,同步一般指主動請求并等待I/O操作完畢的方式,當數據就緒后在讀寫的時候必須阻塞(區別就緒與讀寫二個階段,同步的讀寫必須阻塞),異步則指主動請求數據后便可以繼續處理其它任務,隨后等待I/O,操作完畢的通知,這可以使進程在數據讀寫時也不阻塞。(等待"通知") 服務端 ``` //設置腳本運行時間不限制 set_time_limit(0); $server_socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP); socket_bind($server_socket, '127.0.0.1', '1212'); socket_listen($server_socket, 4); //設置非阻塞模式 socket_set_nonblock($server_socket); do{ //當有連接時讀入數據,并返回 $msg_socket = socket_accept($server_socket); if($msg_socket) { $buff = socket_read($msg_socket, 1024); echo "client: ".$buff; socket_write($msg_socket, $buff); socket_close($msg_socket); } }while(true); socket_close($server_socket); ``` 客戶端 ``` set_time_limit(0); $client_socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP); socket_connect($client_socket, '127.0.0.1', 1212); if(isset($argv[1])) { $send = 'client value '.$argv[1]; } else { $send = "default"; } socket_write($client_socket, $send."\r\n"); $response = socket_read($client_socket, 1024); echo "server: ".$response; socket_close($client_socket); ``` ![](https://img.kancloud.cn/29/cb/29cbb4d70efe1f989063702ad172414f_899x268.png)
                  <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>

                              哎呀哎呀视频在线观看