java 同步、異步、阻塞和非阻塞分析
java 同步、異步、阻塞和非阻塞分析
概要:
正常情況下,我們的程序以同步非阻塞的方式在運行。但是我們的程序總會出現(xiàn)一些耗時操作,比如復(fù)雜的計算(找出1到10億之間的素數(shù))和程序本身無法控制的操作(IO操作、網(wǎng)絡(luò)請求)。包含這些耗時操作的方法我們可以把它稱為阻塞方法,包含這些耗時操作的任務(wù)我們可以把它稱為阻塞任務(wù)。阻塞與非阻塞是以是否耗時來定義的。
如果程序中存在大量阻塞操作,就會影響程序性能。但是阻塞的存在是客觀事實,我們的程序是無法改變它的,一個網(wǎng)絡(luò)請求需要3秒才能響應(yīng),我們不可能讓它1毫秒就能響應(yīng),因為接受請求的服務(wù)器可能完全不由我們控制。但是我們可以改變處理阻塞的方式——以異步的方式處理阻塞任務(wù)。實現(xiàn)異步的主要技術(shù)就是多線程。圖示:

同步和異步是個時序概念。同步就是同時只執(zhí)行一個任務(wù),而異步則是同時執(zhí)行多個任務(wù)。
代碼示例
模擬網(wǎng)絡(luò)請求:
package com.zzj.asyn;
public class HttpRequest {
private Callable callable;
public HttpRequest(Callable callable) {
this.callable = callable;
}
public void send(){
// 模擬網(wǎng)絡(luò)請求
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);
}
}
以同步方式處理阻塞任務(wù):
package com.zzj.asyn;
import com.zzj.asyn.HttpRequest.Callable;
/**
* 以同步的方式處理阻塞任務(wù)
* @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!
以異步的方式處理阻塞任務(wù):
package com.zzj.asyn;
import com.zzj.asyn.HttpRequest.Callable;
/**
* 以異步的方式處理阻塞任務(wù)
* @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!
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Java API方式調(diào)用Kafka各種協(xié)議的方法
本篇文章主要介紹了Java API方式調(diào)用Kafka各種協(xié)議的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09
idea?http?request無法識別環(huán)境變量的解決步驟
AlibabaCloudToolkit插件安裝后在?Editor->File?Types增加?AlibabaCloudROStemplates(JSON)項且會配置為解析*.json?文件,導(dǎo)致http?client無法正確解析http-client.env.json文件而無法讀取環(huán)境變量,本文介紹idea?http?request無法識別環(huán)境變量問題,需要的朋友可以參考下2023-08-08
webuploader+springmvc實現(xiàn)圖片上傳功能
這篇文章主要為大家詳細(xì)介紹了webuploader+springmvc實現(xiàn)圖片上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09
java 輸入3個數(shù)a,b,c,按大小順序輸出的實例講解
今天小編就為大家分享一篇java 輸入3個數(shù)a,b,c,按大小順序輸出的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
maven多profile 打包下 -P參和-D參數(shù)的實現(xiàn)
這篇文章主要介紹了maven多profile 打包下 -P參和-D參數(shù)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
idea maven項目無法識別jar包里的class解決方案
這篇文章主要介紹了idea maven項目無法識別jar包里的class解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06

