| 
									
										
										
										
											2015-10-28 09:55:05 +08:00
										 |  |  | --- | 
					
						
							|  |  |  | layout: pattern | 
					
						
							|  |  |  | title: Producer Consumer | 
					
						
							|  |  |  | folder: producer-consumer | 
					
						
							|  |  |  | permalink: /patterns/producer-consumer/ | 
					
						
							| 
									
										
										
										
											2015-12-28 15:52:44 +02:00
										 |  |  | categories: Concurrency | 
					
						
							|  |  |  | tags: | 
					
						
							|  |  |  |  - Java | 
					
						
							|  |  |  |  - Difficulty-Intermediate | 
					
						
							|  |  |  |  - I/O | 
					
						
							| 
									
										
										
										
											2015-10-28 09:55:05 +08:00
										 |  |  | --- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-03 21:14:30 +01:00
										 |  |  | ## Intent
 | 
					
						
							|  |  |  | Producer Consumer Design pattern is a classic concurrency pattern which reduces | 
					
						
							| 
									
										
										
										
											2015-10-28 09:55:05 +08:00
										 |  |  |  coupling between Producer and Consumer by separating Identification of work with Execution of | 
					
						
							| 
									
										
										
										
											2015-12-28 15:52:44 +02:00
										 |  |  |  Work. | 
					
						
							| 
									
										
										
										
											2015-10-28 09:55:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-03 21:14:30 +01:00
										 |  |  | ## Applicability
 | 
					
						
							|  |  |  | Use the Producer Consumer idiom when | 
					
						
							| 
									
										
										
										
											2015-10-28 09:55:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | * decouple system by separate work in two process produce and consume. | 
					
						
							|  |  |  | * addresses the issue of different timing require to produce work or consuming work |