DEV Community

Prashant Mishra
Prashant Mishra

Posted on

command

Command pattern is one of the behavioral patterns, where a request is wrapped inside an object as command and that object is passed to an invoker, the invoker then looks for an appropriate object that can handle this command and passes the command to the corresponding object, the object then executes the command.

This also follows the OCP solid principle

Let's take an example of the stock market, where Stock is a request that should be bought or sold(command), this Stock is wrapped under Order, this Order is then sent to the broker (Invoker), the broker then analyses the Order to decide whether this is BuyOrder or SellOrder and finally Buy or sell order is performed(execution of the command/request)

command

Stock (request)

public class Stock {
    private String name ;
    private int quantity;
    public Stock(String n, int q){
        this.name = n;
        this.quantity = q;
    }
    public void sell(){
        System.out.println("[Sell order of quantity "+ quantity +" for stock "+name +" has been performed]");
    }
    public void buy(){
        System.out.println("[Buy order of quantity "+ quantity +" for stock "+name +" has been performed]");
    }
}
Enter fullscreen mode Exit fullscreen mode

Order (request wrapped inside an object as a command)

public interface Order {
    public void execute();
}
Enter fullscreen mode Exit fullscreen mode

Concrete Orders

public class BuyOrder implements Order {
    private Stock stock;
    public BuyOrder(Stock s){
        this.stock = s;
    }
    @Override
    public void execute(){
        stock.buy();
    }
}

public class SellOrder implements Order {
    private Stock stock;
    public SellOrder(Stock s){
        this.stock = s;
    }
    @Override
    public void execute(){
        stock.sell();
    }
}
Enter fullscreen mode Exit fullscreen mode

Broker(Invoker that chooses appropriate Object that can handle the command/Order)


import java.util.ArrayList;
import java.util.List;

public class Broker {
    List<Order> orders;
    public Broker(){
        orders = new ArrayList<>();
    }

    public void addOrder(Order e){
        orders.add(e);
    }

    public void placeOrder(){
        for(Order e : orders){
            e.execute();
        }
        orders.clear();// once all the orders are placed by the broker then, the list should be emptied
    }
}
Enter fullscreen mode Exit fullscreen mode

Main


public class Main {
    public static void main(String args[]){
        //requests
        Stock stock = new Stock("TCS",20);
        Stock stock2 = new Stock("Infy",10);
        //requests wrapped inside object(order) as commands
        Order order1 = new BuyOrder(stock);
        Order order2 = new SellOrder(stock2);

        //order is sent to the broker 
        Broker broker = new Broker();
        broker.addOrder(order1);
        broker.addOrder(order2);

        //broker at runtime decides the appropriate Object for the reference Order
        //in other words the invokers decide which object is appropriate and can handle this command/Order
        broker.placeOrder();
    }
}
Enter fullscreen mode Exit fullscreen mode

Output:

[Buy order of quantity 20 for stock TCS has been performed]
[Sell order of quantity 10 for stock Infy has been performed]
Enter fullscreen mode Exit fullscreen mode

Key points for this pattern

  • Follows OCP, and SIP solid principles.
  • Type of order is known at runtime

Top comments (0)