日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java实现线程间通信的四种方式

發(fā)布時間:2025/7/14 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java实现线程间通信的四种方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

synchronized同步
public class MyObject {

synchronized public void methodA() {
//do something....
}

synchronized public void methodB() {
//do some other thing
}
}

public class ThreadA extends Thread {

private MyObject object;
//省略構造方法
@Override
public void run() {
super.run();
object.methodA();
}
}

public class ThreadB extends Thread {

private MyObject object;
//省略構造方法
@Override
public void run() {
super.run();
object.methodB();
}
}

public class Run {
public static void main(String[] args) {
MyObject object = new MyObject();

//線程A與線程B 持有的是同一個對象:object
ThreadA a = new ThreadA(object);
ThreadB b = new ThreadB(object);
a.start();
b.start();
}
}
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
37
38
39
40
41
42
43
44
由于線程A和線程B持有同一個MyObject類的對象object,盡管這兩個線程需要調用不同的方法,但是它們是同步執(zhí)行的,比如:線程B需要等待線程A執(zhí)行完了methodA()方法之后,它才能執(zhí)行methodB()方法。這樣,線程A和線程B就實現了通信。

這種方式,本質上就是“共享內存”式的通信。多個線程需要訪問同一個共享變量,誰拿到了鎖(獲得了訪問權限),誰就可以執(zhí)行。

while輪詢

其實就是多線程同時執(zhí)行,會犧牲部分CPU性能。

在這種方式下,線程A不斷地改變條件,線程ThreadB不停地通過while語句檢測這個條件(list.size()==5)是否成立 ,從而實現了線程間的通信。但是這種方式會浪費CPU資源。之所以說它浪費資源,是因為JVM調度器將CPU交給線程B執(zhí)行時,它沒做啥“有用”的工作,只是在不斷地測試 某個條件是否成立。就類似于現實生活中,某個人一直看著手機屏幕是否有電話來了,而不是: 在干別的事情,當有電話來時,響鈴通知TA電話來了。

import java.util.ArrayList;
import java.util.List;

public class MyList {

private List<String> list = new ArrayList<String>();
public void add() {
list.add("elements");
}
public int size() {
return list.size();
}
}

import mylist.MyList;

public class ThreadA extends Thread {

private MyList list;

public ThreadA(MyList list) {
super();
this.list = list;
}

@Override
public void run() {
try {
for (int i = 0; i < 10; i++) {
list.add();
System.out.println("添加了" + (i + 1) + "個元素");
Thread.sleep(1000);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

import mylist.MyList;

public class ThreadB extends Thread {

private MyList list;

public ThreadB(MyList list) {
super();
this.list = list;
}

@Override
public void run() {
try {
while (true) {
if (list.size() == 5) {
System.out.println("==5, 線程b準備退出了");
throw new InterruptedException();
}
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

import mylist.MyList;
import extthread.ThreadA;
import extthread.ThreadB;

public class Test {

public static void main(String[] args) {
MyList service = new MyList();

ThreadA a = new ThreadA(service);
a.setName("A");
a.start();

ThreadB b = new ThreadB(service);
b.setName("B");
b.start();
}
}
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
wait/notify機制
public class MyList {
private static List<String> list = new ArrayList<String>();

public static void add() {
list.add("anyString");
}

public static int size() {
return list.size();
}
}


public class ThreadA extends Thread {

private Object lock;

public ThreadA(Object lock) {
super();
this.lock = lock;
}

@Override
public void run() {
try {
synchronized (lock) {
if (MyList.size() != 5) {
System.out.println("wait begin " + System.currentTimeMillis());
lock.wait();
System.out.println("Interruption!!!");
//lock.wait();
lock.notify();
lock.wait();
System.out.println("wait end " + System.currentTimeMillis());
}
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}


public class ThreadB extends Thread {

private Object lock;

public ThreadB(Object lock) {
super();
this.lock = lock;
}

@Override
public void run() {
try {
synchronized (lock) {
for (int i = 0; i < 10; i++) {
MyList.add();
if (MyList.size() == 5) {
lock.notify();
System.out.println("已經發(fā)出了通知");
lock.wait();
}
System.out.println("添加了" + (i + 1) + "個元素!");
Thread.sleep(1000);
}
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

public class Test {
public static void main(String[] args) {
try {
Object lock = new Object();

ThreadA a = new ThreadA(lock);
a.start();

Thread.sleep(50);

ThreadB b = new ThreadB(lock);
b.start();
} catch (InterruptedException e) {
e.printStackTrace();
}
}

}
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
wait begin 1498007974397
添加了1個元素!
添加了2個元素!
添加了3個元素!
添加了4個元素!
已經發(fā)出了通知
Interruption!!!
添加了5個元素!
添加了6個元素!
添加了7個元素!
添加了8個元素!
添加了9個元素!
添加了10個元素!
1
2
3
4
5
6
7
8
9
10
11
12
13
線程A要等待某個條件滿足時(list.size()==5),才執(zhí)行操作。線程B則向list中添加元素,改變list 的size。

A,B之間如何通信的呢?也就是說,線程A如何知道 list.size() 已經為5了呢?

這里用到了Object類的 wait() 和 notify() 方法。

當條件未滿足時(list.size() !=5),線程A調用wait() 放棄CPU,并進入阻塞狀態(tài)。—不像②while輪詢那樣占用CPU

當條件滿足時,線程B調用 notify()通知 線程A,所謂通知線程A,就是喚醒線程A,并讓它進入可運行狀態(tài)。

這種方式的一個好處就是CPU的利用率提高了。

?

管道通信
管道流主要用來實現兩個線程之間的二進制數據的傳播,下面以PipedInputStream類和PipedOutputStream類為例,實現生產者-消費者:

package test.pipe;

import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;

/**
* 我們以數字替代產品 生產者每5秒提供5個產品,放入管道
*/
class MyProducer extends Thread {

private PipedOutputStream outputStream;

private int index = 0;

public MyProducer(PipedOutputStream outputStream) {
this.outputStream = outputStream;
}

@Override
public void run() {
while (true) {
try {
for (int i = 0; i < 5; i++) {
outputStream.write(index++);
}
} catch (IOException e) {
e.printStackTrace();
}

try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}

/**
* 消費者每0.5秒從管道中取1件產品,并打印剩余產品數量,并打印產品信息(以數字替代)
*/
class MyConsumer extends Thread {

private PipedInputStream inputStream;

public MyConsumer(PipedInputStream inputStream) {
this.inputStream = inputStream;
}

@Override
public void run() {
while (true) {
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
try {
int count = inputStream.available();
if (count > 0) {
System.out.println("rest product count: " + count);
System.out.println("get product: " + inputStream.read());
}
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
}

public class PipeTest1 {

public static void main(String[] args) {

PipedOutputStream pos = new PipedOutputStream();
PipedInputStream pis = new PipedInputStream();
try {
pis.connect(pos);
} catch (IOException e) {
e.printStackTrace();
}

new MyProducer(pos).start();
new MyConsumer(pis).start();

}
}
---------------------
作者:Hadwin1991
來源:CSDN
原文:https://blog.csdn.net/Hadwin1991/article/details/73527835
版權聲明:本文為博主原創(chuàng)文章,轉載請附上博文鏈接!

轉載于:https://www.cnblogs.com/lgyxrk/p/10404846.html

《新程序員》:云原生和全面數字化實踐50位技術專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的java实现线程间通信的四种方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 天堂中文在线最新 | 午夜国产一级 | 亚洲av无码日韩精品影片 | 亚洲少妇色 | 久久久国产精品久久久 | 91在线视频网址 | 又黄又色又爽 | 久久欲| 日本一区二区视频在线播放 | 亚洲国产精品成人午夜在线观看 | 麻豆视频传媒入口 | 亚洲欧美影院 | 国产av不卡一区 | 永久免费不卡在线观看黄网站 | 国产视频一区二区在线播放 | 久久久久久久久久一区二区三区 | 日日躁狠狠躁 | 成人网页 | 久久国产热 | 香蕉视频在线免费看 | 一区二区免费在线播放 | 中文字幕性| 日韩在线小视频 | 亚洲第一色视频 | 91av影视 | 精品国产乱码久久久久久郑州公司 | 精品在线第一页 | 精品成人一区二区 | 国产精品久久久久久免费播放 | 久久中文字幕电影 | 这里只有精品免费视频 | 97九色| 欧洲金发美女大战黑人 | 亚洲欧洲无码一区二区三区 | 欧美xxxxbbb | 久久中文字幕一区 | 精品国产鲁一鲁一区二区三区 | 亚洲天堂小说 | 亚州黄色 | 国产图区 | 99精品欧美一区二区蜜桃免费 | 国产精品夜色一区二区三区 | 精品动漫一区二区三区的观看方式 | 久久久久久久久久久久91 | 亚洲日本久久 | 亚洲奶汁xxxx哺乳期 | 亚洲av无码片一区二区三区 | 精品国产a线一区二区三区东京热 | 久久久视| av在线观| 欧美精品亚洲精品日韩精品 | 免费在线观看黄色av | 9i精品福利一区二区三区 | 最新黄网 | 国产一区a| 国产精品色悠悠 | 欧美精品久久久久久 | 国产porn | 久久久久久久人妻无码中文字幕爆 | 黄网在线免费观看 | 欧美一区二区三区日韩 | 自拍视频国产 | 京香julia在线观看 | 日韩视频在线免费观看 | 永久免费成人代码 | 色久天| 性开放耄耋老妇hd | 欧美综合图片 | 亚洲色图15p| 日韩视频一区二区三区 | 老女人一区 | 亚洲天堂午夜 | 国产一区二区视频播放 | 精品+无码+在线观看 | 韩日av片 | 色欲亚洲Av无码精品天堂 | a级片在线免费看 | 亚洲一区二区图片 | 日韩免费大片 | 91成人在线免费视频 | 欧美亚洲大片 | 深夜视频在线观看 | 亚洲av成人一区二区 | 依依成人在线视频 | 一本久道久久 | 亚洲一区二区色 | 欧美大尺度视频 | 日本一区免费电影 | 好色先生tv官网 | 欧美精产国品一二三 | 风间由美av | 国产日韩欧美日韩大片 | 国产免费又粗又猛又爽 | 一区二区在线 | 国产福利在线 | 色网导航站 | 国产精品36p | japanesexxxx日本妞 | 天天做天天射 |