java同步、異步、阻塞和非阻塞分析

java 同步、異步、阻塞和非阻塞分析

創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網(wǎng)站設計制作、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的寧江網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

概要:

正常情況下,我們的程序以同步非阻塞的方式在運行。但是我們的程序總會出現(xiàn)一些耗時操作,比如復雜的計算(找出1到10億之間的素數(shù))和程序本身無法控制的操作(IO操作、網(wǎng)絡請求)。包含這些耗時操作的方法我們可以把它稱為阻塞方法,包含這些耗時操作的任務我們可以把它稱為阻塞任務。阻塞與非阻塞是以是否耗時來定義的。

如果程序中存在大量阻塞操作,就會影響程序性能。但是阻塞的存在是客觀事實,我們的程序是無法改變它的,一個網(wǎng)絡請求需要3秒才能響應,我們不可能讓它1毫秒就能響應,因為接受請求的服務器可能完全不由我們控制。但是我們可以改變處理阻塞的方式——以異步的方式處理阻塞任務。實現(xiàn)異步的主要技術(shù)就是多線程。圖示:

java 同步、異步、阻塞和非阻塞分析

同步和異步是個時序概念。同步就是同時只執(zhí)行一個任務,而異步則是同時執(zhí)行多個任務。

代碼示例

模擬網(wǎng)絡請求:


package com.zzj.asyn; 
 
public class HttpRequest { 
  private Callable callable; 
   
  public HttpRequest(Callable callable) { 
    this.callable = callable; 
  } 
   
  public void send(){ 
    // 模擬網(wǎng)絡請求 
    try { 
      Thread.sleep(1000 * 5); 
    } catch (InterruptedException e) { 
      e.printStackTrace(); 
      Thread.currentThread().interrupt(); 
    } 
    // 回調(diào) 
    this.callable.call("Hello world!"); 
  } 
   
  public interface Callable{ 
    void call(String result); 
  } 
} 

以同步方式處理阻塞任務:

package com.zzj.asyn; 
 
import com.zzj.asyn.HttpRequest.Callable; 
 
/** 
 * 以同步的方式處理阻塞任務 
 * @author lenovo 
 * 
 */ 
public class App { 
  public static void main(String[] args) { 
    new HttpRequest(new Callable() { 
      @Override 
      public void call(String result) { 
        System.out.println("Thread:" + Thread.currentThread().getName()); 
        System.out.println("Message from remote server:" + result); 
      } 
    }).send(); 
    System.out.println("Thread " + Thread.currentThread().getName() + " is over!"); 
  } 
} 

結(jié)果:

Thread:main 
Message from remote server:Hello world! 
Thread main is over! 

以異步的方式處理阻塞任務:

package com.zzj.asyn; 
 
import com.zzj.asyn.HttpRequest.Callable; 
 
/** 
 * 以異步的方式處理阻塞任務 
 * @author lenovo 
 * 
 */ 
public class App2 { 
  public static void main(String[] args) { 
    new Thread(new Runnable() { 
      @Override 
      public void run() { 
        new HttpRequest(new Callable() { 
          @Override 
          public void call(String result) { 
            System.out.println("Thread:" + Thread.currentThread().getName()); 
            System.out.println("Message from remote server:" + result); 
          } 
        }).send(); 
      } 
    }).start(); 
    System.out.println("Thread " + Thread.currentThread().getName() + " is over!"); 
  } 
} 

結(jié)果:

Thread main is over! 
Thread:Thread-0 
Message from remote server:Hello world! 

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

文章標題:java同步、異步、阻塞和非阻塞分析
新聞來源:http://bm7419.com/article22/jdegcc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、移動網(wǎng)站建設、ChatGPT、營銷型網(wǎng)站建設、App設計、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站