82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| layout: pattern
 | |
| title: Callback
 | |
| folder: callback
 | |
| permalink: /patterns/callback/
 | |
| categories: Idiom
 | |
| tags:
 | |
|  - Reactive
 | |
| ---
 | |
| 
 | |
| ## Intent
 | |
| Callback is a piece of executable code that is passed as an argument to other code, which is expected to call back 
 | |
| (execute) the argument at some convenient time.
 | |
| 
 | |
| ## Explanation
 | |
| 
 | |
| Real world example
 | |
| 
 | |
| > We need to be notified after executing task has finished. We pass a callback method for the executor and wait for it to call back on us.     
 | |
| 
 | |
| In plain words
 | |
| 
 | |
| > Callback is a method passed to the executor which will be called at defined moment. 
 | |
| 
 | |
| Wikipedia says
 | |
| 
 | |
| > In computer programming, a callback, also known as a "call-after" function, is any executable code that is passed as an argument to other code; that other code is expected to call back (execute) the argument at a given time.
 | |
| 
 | |
| **Programmatic Example**
 | |
| 
 | |
| Callback is a simple interface with single method.
 | |
| 
 | |
| ```java
 | |
| public interface Callback {
 | |
| 
 | |
|   void call();
 | |
| }
 | |
| ```
 | |
| 
 | |
| Next we define a task that will execute the callback after the task execution has finished.
 | |
| 
 | |
| ```java
 | |
| public abstract class Task {
 | |
| 
 | |
|   final void executeWith(Callback callback) {
 | |
|     execute();
 | |
|     Optional.ofNullable(callback).ifPresent(Callback::call);
 | |
|   }
 | |
| 
 | |
|   public abstract void execute();
 | |
| }
 | |
| 
 | |
| public final class SimpleTask extends Task {
 | |
| 
 | |
|   private static final Logger LOGGER = getLogger(SimpleTask.class);
 | |
| 
 | |
|   @Override
 | |
|   public void execute() {
 | |
|     LOGGER.info("Perform some important activity and after call the callback method.");
 | |
|   }
 | |
| }
 | |
| ```
 | |
| 
 | |
| Finally here's how we execute a task and receive a callback when it's finished.
 | |
| 
 | |
| ```java
 | |
|     var task = new SimpleTask();
 | |
|     task.executeWith(() -> LOGGER.info("I'm done now."));
 | |
| ```
 | |
| 
 | |
| ## Class diagram
 | |
| 
 | |
| 
 | |
| ## Applicability
 | |
| Use the Callback pattern when
 | |
| 
 | |
| * when some arbitrary synchronous or asynchronous action must be performed after execution of some defined activity.
 | |
| 
 | |
| ## Real world examples
 | |
| 
 | |
| * [CyclicBarrier](http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CyclicBarrier.html#CyclicBarrier%28int,%20java.lang.Runnable%29) constructor can accept callback that will be triggered every time when barrier is tripped.
 |