Java中實現(xiàn)兩個線程交替運行的方法
今天筆者收到老師的一個題目,讓我準(zhǔn)備兩個流程,依次實現(xiàn)輸出以下信息
如:
線程A 打印 字母a ,線程B 打印數(shù)字1
線程A 打印 字母b ,線程B 打印數(shù)字2
線程A 打印 字母c ,線程B 打印數(shù)字3
線程A 打印 字母d ,線程B 打印數(shù)字4
。。。
依次打印完畢26個字母和26個數(shù)字
,輸出效果為:
a1b2c3...z26
下文筆者就將具體的實現(xiàn)思路展示如下:
1.將借助多線程的wait方法
2.借助一個外部變量
package com.java265.other; public class Test6 { /* * 兩個線程 一個線程輸出 a b c d e f 一個線程輸出 1 2 3 4 5 交叉輸出 a 1 b 2 c 3 */ static boolean flag = false; public static void main(String[] args) { Object o = new Object(); Thread t1, t2; t1 = new Thread(() -> { for (int i = 0; i < 26; ) { synchronized (o) { if (!flag) { char t = (char) (i + (int) 'a'); System.out.print(t); i++; try { o.wait(); } catch (InterruptedException e) { e.printStackTrace(); } flag = false; o.notifyAll(); } } } }); t2 = new Thread(() -> { for (int i = 1; i <= 26;) { synchronized (o) { if (flag) { System.out.print(i); i++; try { o.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } flag = true; o.notifyAll(); } } }); t1.start(); t2.start(); } }
http://java265.com/JavaMianJing/202112/16383980681974.html
到此這篇關(guān)于Java中實現(xiàn)兩個線程交替運行的流程的文章就介紹到這了,更多相關(guān)Java線程交替運行內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot線程池和Java線程池的使用和實現(xiàn)原理解析
這篇文章主要介紹了SpringBoot線程池和Java線程池的用法和實現(xiàn)原理,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04在Java8與Java7中HashMap源碼實現(xiàn)的對比
這篇文章主要介紹了在Java8與Java7中HashMap源碼實現(xiàn)的對比,內(nèi)容包括HashMap 的原理簡單介紹、結(jié)合源碼在Java7中是如何解決hash沖突的以及優(yōu)缺點,結(jié)合源碼以及在Java8中如何解決hash沖突,balance tree相關(guān)源碼介紹,需要的朋友可以參考借鑒。2017-01-01Java使用Callable接口實現(xiàn)多線程的實例代碼
這篇文章主要介紹了Java使用Callable接口實現(xiàn)多線程的實例代碼,實現(xiàn)Callable和實現(xiàn)Runnable類似,但是功能更強大,具體表現(xiàn)在可以在任務(wù)結(jié)束后提供一個返回值,Runnable不行,call方法可以拋出異,Runnable的run方法不行,需要的朋友可以參考下2023-08-08Java中的WeakHashMap、LinkedHashMap、TreeMap與Set詳解
這篇文章主要介紹了Java中的WeakHashMap、LinkedHashMap、TreeMap與Set詳解,在JVM中,一個對象如果不再被使用就會被當(dāng)做垃圾給回收掉,判斷一個對象是否是垃圾,我們的WeakHashMap就是基于弱引用,需要的朋友可以參考下2023-09-09