多线程交替打印示例
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;
/**
* 可以實(shí)現(xiàn)指定的打印次數(shù),和每次打印的個(gè)數(shù),
* 按線程順序進(jìn)行交替打印,打印完之后會(huì)停止多線程
* 思路:不同線程類(lèi)實(shí)現(xiàn)不同的邏輯,通過(guò)并發(fā)包下的原子類(lèi)來(lái)進(jìn)行控制停止的時(shí)機(jī),
* 用condition 來(lái)進(jìn)行控制不同線程之間的通信,用參數(shù)控制打印元素的個(gè)數(shù)和總共打印的輪數(shù)
*/
public class TestCondition {
public int signal ;
public ReentrantLock lock = new ReentrantLock();
public Condition conditionA = lock.newCondition();
public Condition conditionB = lock.newCondition();
public Condition conditionC = lock.newCondition();
public AtomicInteger shutdown = new AtomicInteger(5);
public int printANum;
public int printBNum;
public int printCNum;
public int printCount;
public TestCondition(int printANum,int printBNum,int printCNum,int printCount){
this.printANum = printANum;
this.printBNum = printBNum;
this.printCNum = printCNum;
this.printCount = printCount;
}
public void printA(){
try {
lock.lock();
while (signal!=0 ){
conditionA.await();
}
for (int i = 1; i<=printANum;i++){
System.out.print("A");
}
signal++;
conditionB.signal();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void printB(){
try {
lock.lock();
while (signal!=1 ){
conditionB.await();
}
for (int i = 1; i<=printBNum;i++){
System.out.print("B");
}
signal++;
conditionC.signal();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void printC(){
try {
lock.lock();
if (signal!=2 ){
conditionC.await();
}
for (int i = 1; i<=printCNum;i++){
System.out.print("C");
}
signal = 0;
conditionA.signal();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public static void main(String[] args) {
TestCondition testCondition =
new TestCondition(1,1,1,5);
A a = new A(testCondition);
B b = new B(testCondition);
C c = new C(testCondition);
new Thread(a).start();
new Thread(b).start();
new Thread(c).start();
}
}
class A implements Runnable{
public TestCondition testCondition;
public A (TestCondition testCondition){
this.testCondition = testCondition;
}
public void run() {
while (testCondition.shutdown.get()>0){
testCondition.printA();
testCondition.shutdown.decrementAndGet();
}
}
}
class B implements Runnable {
public TestCondition testCondition;
public B (TestCondition testCondition){
this.testCondition = testCondition;
}
public void run() {
while (testCondition.shutdown.get()>0){
testCondition.printB();
}
}
}
class C implements Runnable {
public TestCondition testCondition;
public C (TestCondition testCondition){
this.testCondition = testCondition;
}
public void run() {
while (testCondition.shutdown.get()>0){
testCondition.printC();
}
}
}
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;
/**
* 可以實(shí)現(xiàn)指定的打印次數(shù),和每次打印的個(gè)數(shù),
* 按線程順序進(jìn)行交替打印,打印完之后會(huì)停止多線程
* 思路:不同線程類(lèi)實(shí)現(xiàn)不同的邏輯,通過(guò)并發(fā)包下的原子類(lèi)來(lái)進(jìn)行控制停止的時(shí)機(jī),
* 用condition 來(lái)進(jìn)行控制不同線程之間的通信,用參數(shù)控制打印元素的個(gè)數(shù)和總共打印的輪數(shù)
*/
public class TestCondition {
public int signal ;
public ReentrantLock lock = new ReentrantLock();
public Condition conditionA = lock.newCondition();
public Condition conditionB = lock.newCondition();
public Condition conditionC = lock.newCondition();
public AtomicInteger shutdown = new AtomicInteger(5);
public int printANum;
public int printBNum;
public int printCNum;
public int printCount;
public TestCondition(int printANum,int printBNum,int printCNum,int printCount){
this.printANum = printANum;
this.printBNum = printBNum;
this.printCNum = printCNum;
this.printCount = printCount;
}
public void printA(){
try {
lock.lock();
while (signal!=0 ){
conditionA.await();
}
for (int i = 1; i<=printANum;i++){
System.out.print("A");
}
signal++;
conditionB.signal();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void printB(){
try {
lock.lock();
while (signal!=1 ){
conditionB.await();
}
for (int i = 1; i<=printBNum;i++){
System.out.print("B");
}
signal++;
conditionC.signal();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void printC(){
try {
lock.lock();
if (signal!=2 ){
conditionC.await();
}
for (int i = 1; i<=printCNum;i++){
System.out.print("C");
}
signal = 0;
conditionA.signal();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public static void main(String[] args) {
TestCondition testCondition =
new TestCondition(1,1,1,5);
A a = new A(testCondition);
B b = new B(testCondition);
C c = new C(testCondition);
new Thread(a).start();
new Thread(b).start();
new Thread(c).start();
}
}
class A implements Runnable{
public TestCondition testCondition;
public A (TestCondition testCondition){
this.testCondition = testCondition;
}
public void run() {
while (testCondition.shutdown.get()>0){
testCondition.printA();
testCondition.shutdown.decrementAndGet();
}
}
}
class B implements Runnable {
public TestCondition testCondition;
public B (TestCondition testCondition){
this.testCondition = testCondition;
}
public void run() {
while (testCondition.shutdown.get()>0){
testCondition.printB();
}
}
}
class C implements Runnable {
public TestCondition testCondition;
public C (TestCondition testCondition){
this.testCondition = testCondition;
}
public void run() {
while (testCondition.shutdown.get()>0){
testCondition.printC();
}
}
}
轉(zhuǎn)載于:https://www.cnblogs.com/mishaka/p/11140031.html
總結(jié)
- 上一篇: Python常见面试题:TCP 协议中的
- 下一篇: linux 手动睡眠