State Pattern

A monolithic object's behavior is a function of its state, and it must change its behavior at run-time depending on that state. The State Pattern is a solution to the problem of how to make behavior depend on state.

Intent

  • Allow an object to alter its behavior when its internal state changes.

Implementation

Class Diagram of State Pattern

Let's use the state of an mp3 player to give an example. First we set up a Context for the mp3 player.

// MP3PlayerContext.java
public class MP3PlayerContext {
    private State state;

    public MP3PlayerContext() {
        this.state = new StandbyState();
    }

    public void press() {
        state.pressPlay(this);
    }

    public void setState(State state) {
        this.state = state;
    }

    public void getState() {
        System.out.println(state.getState());
    }
}

Here is our State interface, on which the pressPlay() imitates the play botton.

// State.java
public interface State {

    void pressPlay(MP3PlayerContext context);
    String getState();
}

Now, we create states for StandbyState and PlayingState.

// PlayingState.java
public class PlayingState implements State {

    public void pressPlay(MP3PlayerContext context) {
        context.setState(new StandbyState());
    }

    @Override
    public String getState() {
        return "Playing...";
    }
}
// StandbyState.java
public class StandbyState implements State {

    public void pressPlay(MP3PlayerContext context) {
        context.setState(new PlayingState());
    }

    @Override
    public String getState() {
        return "Stand By...";
    }
}

Our client presses the button to turn on the mp3, and then presses again to turn it off.

// ClientDemo.java
public class ClientDemo {

    public static void main(String[] args) {

        MP3PlayerContext mp3Player = new MP3PlayerContext();
        mp3Player.press();
        mp3Player.getState();
        mp3Player.press();
        mp3Player.getState();
    }
}

Output:

Playing...
Stand By...

More

State Pattern vs Finite State Machine

According to this stackoverflow post, the State Pattern is more decentralized while Finite State Machine is more monolithic:

The way I describe this difference to my colleagues is that state patterns are a more decentralized implementation of many stand alone encapsulated states whereas state machines are more monolithic. The monolithic nature of state machines means that a single state will be harder to reuse in a different machine and that it is harder to break a state machine up into multiple compilation units. On the other hand this monolithic design allows far better optimization of state machines and allows many implementations to represent all transition information in one place in a table...

Notice that in State Pattern, switching states requires an allocation, which actually kills speed. Use the State Pattern in cases where speed is a not an issue.

Reference

Code Project
DZone
Hackjustu Dojo (my blog)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • **2014真题Directions:Read the following text. Choose the be...
    又是夜半惊坐起阅读 9,939评论 0 23
  • 上一章:婉豆说(03) 8.其实没那么想念 玉兰树的叶子仍绿着,漳江上的渔船在冬季里也住着人,曾伏在沈哲肩头,走过...
    乔三的马甲阅读 346评论 0 2
  • 《精疲力尽》 二 大学初体验 高考前的那段日子,对于大多数人来说都很难忘。对于我来说,用复读两年...
    精疲力尽的小七阅读 511评论 0 0
  • 28 ProGuard混淆介绍 28.1ProGuard简介 Java源代码(.java文件)通常被编译为字节码(...
    xjbclz阅读 249评论 0 0
  • 美食品鉴大师蔡澜在著作《暖食》中对蛋炒饭有这样一段绝妙的表述: “炒饭的最高境界在于炒得蛋包住米饭,呈金黄,才能叫...
    ShannaShau阅读 364评论 0 0