国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java多線程 Guarded Suspension設計模式

Java多線程 Guarded Suspension設計模式

2022-03-05 14:59冬日毛毛雨 Java教程

這篇文章主要介紹了Java多線程 Guarded Suspension設計模式,Guarded Suspension意為保護暫停,其核心思想是僅當服務進程準備好時,才提供服務,文章圍繞Java多線程 Guarded Suspension展開內容,需要的朋友可以參考一下

前言:

Guarded Suspension意為保護暫停,其核心思想是僅當服務進程準備好時,才提供服務。設想一種場景,服務器可能會在很短時間內承受大量的客戶端請求,客戶端請求的數量可能超過服務器本身的即時處理能力,而服務端程序又不能丟棄任何一個客戶請求。此時,最佳的處理方案莫過于讓客戶端要求進行排隊,由服務端程序一個接一個處理。這樣,既保證了所有的客戶端請求均不丟失,同時也避免了服務器由于同時處理太多的請求而崩潰

1.Guarded Suspension模式的結構

Guarded Suspension模式的主要成員有:RequestRequestQueueClientThreadServerThread

  • Request:表示客戶端請求
  • RequestQueue:用于保存客戶端請求隊列
  • ClientThread:客戶端進程
  • ServerThread:服務器進程

其中,ClientThread負責不斷發起請求,并將請求對象放入請求隊列。ServerThread則根據其自身的狀態,在有能力處理請求時,從RequestQueue中提取請求對象加以處理。

從流程圖中可以看到,客戶端的請求數量超過了服務線程的能力。在頻繁的客戶端請求中,RequestQueue充當了中間緩存,存放未處理的請求,保證了客戶請求不丟失,同時也保護了服務線程不會受到大量并發的請求,而導致計算機資源不足

2. Guarded Suspension模式的簡單實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
public class ClientThread extends Thread {
 
    private final RequestQueue queue;
 
    private final Random random;
 
    private final String sendValue;
 
    public ClientThread(RequestQueue queue, String sendValue) {
        this.queue = queue;
        this.sendValue = sendValue;
        this.random = new Random(System.currentTimeMillis());
    }
 
    @Override
    public void run() {
 
        for (int i = 0; i < 10; i++) {
            System.out.println("Client -> request " + sendValue);
            queue.putRequest(new Request(sendValue));
 
            try {
                Thread.sleep(random.nextInt(1000));
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
?
1
2
3
4
5
6
7
8
9
10
11
12
public class Request {
 
    private final String value;
 
    public Request(String value) {
        this.value = value;
    }
 
    public String getValue() {
        return value;
    }
}
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
public class RequestQueue {
 
    private final LinkedList<Request> queue = new LinkedList<>();
 
    public Request getRequest() {
        synchronized (queue) {
            while (queue.size() <= 0) {
                try {
                    queue.wait();
                } catch (InterruptedException e) {
                    return null;
                }
            }
            return queue.removeFirst();
        }
    }
 
    public void putRequest(Request request) {
 
        synchronized (queue) {
            queue.addLast(request);
            queue.notifyAll();
        }
    }
}
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
public class ServerThread extends Thread {
 
    private final RequestQueue queue;
 
    private final Random random;
 
    private volatile boolean closed = false;
 
    public ServerThread(RequestQueue queue) {
        this.queue = queue;
        random = new Random(System.currentTimeMillis());
    }
 
    @Override
    public void run() {
 
        while (!closed) {
            Request request = queue.getRequest();
            if (null == request) {
                System.out.println("Received the empty request.");
                continue;
            }
            System.out.println("Server ->" + request.getValue());
            try {
                Thread.sleep(random.nextInt(1000));
            } catch (InterruptedException e) {
                return;
            }
        }
    }
 
    public void close() {
        this.closed = true;
        this.interrupt();
    }
}
?
1
2
3
4
5
6
7
8
9
10
11
12
public class SuspensionClient {
    public static void main(String[] args) throws InterruptedException {
 
        final RequestQueue queue = new RequestQueue();
        new ClientThread(queue,"Jack").start();
        ServerThread serverThread =  new ServerThread(queue);
        serverThread.start();
 
        Thread.sleep(10000);
        serverThread.close();
    }
}

運行:

Client -> request Jack
Server ->Jack
Client -> request Jack
Server ->Jack
Client -> request Jack
Server ->Jack
Client -> request Jack
Server ->Jack
Client -> request Jack
Client -> request Jack
Client -> request Jack
Server ->Jack
Client -> request Jack
Client -> request Jack
Server ->Jack
Client -> request Jack
Server ->Jack
Server ->Jack
Server ->Jack
Server ->Jack
Received the empty request.

到此這篇關于Java多線程 Guarded Suspension設計模式的文章就介紹到這了,更多相關Java多線程 Guarded Suspension內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://juejin.cn/post/7022609159912685575

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久久久香蕉 | 日韩一区二区在线免费 | 香蕉久久夜色精品国产使用方法 | 乳首在线| 97精品久久| 韩日中文字幕 | 欧美精品成人一区二区三区四区 | 精品久久网 | 寡妇高潮免费视频一区二区三区 | 欧美一级在线 | 国产高清一区二区 | 综合激情网 | 91毛片视频 | 亚洲国产精品一区二区久久,亚洲午夜 | 免费看亚洲 | 国内自拍视频在线观看 | 成人久久久久久久 | 深夜在线视频 | 国产色| 国产一区二区三区 | a在线观看免费视频 | 久草久| 国产成人精品综合 | 一级片在线观看 | 国产精品中文在线 | 久久人人爽爽爽人久久久 | 日韩在线精品视频 | 久久精品日产第一区二区三区 | 亚洲精品日本 | 国产精品99一区二区三区 | 亚洲天堂久久 | 一区二区三区影视 | 国产成人av在线播放 | 亚洲久久 | 黄色网日本 | 亚洲成人av在线 | 欧美影 | 天堂资源最新在线 | 欧美精产国品一二三区 | 国产麻豆91视频 | 亚洲国产精品久久久 |