Java(자바) BlockingQueue - 설명
① 멀티 스레드(Multi-Thread) 환경에서 Queue는 다양하게 활용 될 수 있어요.
② BlockingQueue를 사용함으로써 Thread-safe 하게 Producer, Consumer 패턴을 구현할 수 있어요.
③ 보통 RabbitMQ 등과 같이 메세지 처리 및 Push 처리 기술 분야에 활용 되고 있어요.
Java(자바) BlockingQueue - Producer 및 Consumer 소스 코드
원본코드
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 92 | //Message 클래스 선언 public class Message { private String msg; public Message(String str){ this.msg=str; } public String getMsg() { return msg; } } //Producer 클래스 선언 import java.util.concurrent.BlockingQueue; public class Producer implements Runnable{ private BlockingQueue<Message> queue; public Producer(BlockingQueue<Message> q){ this.queue=q; } @Override public void run() { //기본 메세지 삽입 for(int i=1; i<31; i++){ Message msg = new Message(""+i); try { Thread.sleep(i); queue.put(msg); System.out.println("Produced "+msg.getMsg()); } catch (InterruptedException e) { e.printStackTrace(); } } //종료 문자열 삽입 Message msg = new Message("exit"); try { queue.put(msg); } catch (InterruptedException e) { e.printStackTrace(); } } } //Consumer 클래스 선언 import java.util.concurrent.BlockingQueue; public class Consumer implements Runnable{ private BlockingQueue<Message> queue; public Consumer(BlockingQueue<Message> q){ this.queue=q; } @Override public void run() { try{ Message msg; //exit 메세지 확인 후 종료 while((msg = queue.take()).getMsg() !="exit"){ Thread.sleep(10); System.out.println("Consumed "+msg.getMsg()); } }catch(InterruptedException e) { e.printStackTrace(); } } } //실행 클래스 선언 import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; public class ProducerConsumerTest { public static void main(String[] args) { //사이즈 기본 30 BlockingQueue<Message> queue = new ArrayBlockingQueue<Message>(30); Producer producer = new Producer(queue); Consumer consumer = new Consumer(queue); //Producer(생산자) 큐에 메세지 생산 시작 new Thread(producer).start(); //Consumer(소비자) 큐로부터 메세지 소비 시작 new Thread(consumer).start(); System.out.println("Producer and Consumer 테스트 시작!"); } } | cs |
실행화면
- 패키지 구조 확인
Java(자바) BlockingQueue - 소스 다운
자바 API 문서 참고 : https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/BlockingQueue.html
'언어 > Java' 카테고리의 다른 글
Java(자바) 디자인패턴 - 전략(Strategy) 패턴 설명 및 예제소스 (3) | 2018.04.18 |
---|---|
Java(자바) Runtime - 외부 프로세스(exec) 실행 예제 소스 (3) | 2017.12.29 |
Java(자바) 알고리즘 - 문자열로 서로 다른 단어 만들어내기(Anagram) (2) | 2017.12.25 |
Java(자바) - Map(맵) 중요한 9가지 사용법 설명 (0) | 2017.11.15 |
Java(자바) - 멀티쓰레드(Multi Thread) 동기화 간단 쉬운 예제 (0) | 2017.09.11 |