9cubed
ブログ | PHP | JavaScript | TypeScript | Vue.js | Laravel | Tailwind | Vite | Python | MariaDB | SQLite | Node.js | Linux | PowerShell | Docker | Git | Web | その他
プログラミング講座

第104回 Stateパターンについて

公開日:2014-10-22
更新日:2019-05-11

1. 概要

独り言によるプログラミング講座「第104回 Stateパターンについて」です。
デザインパターンの1つである State パターンについて説明しています。

2. 動画



3. 動画中に書いたソース

namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            //★独り言によるプログラミング講座

            //■Stateパターンについて
            //  状況に応じて機能を変更するパターン

            //  洗濯機
            //  状況:洗い、すすぎ、脱水、乾燥
        }

        private void button1_Click(object sender, EventArgs e)
        {
            洗濯機 obj = new 洗濯機();
            obj.洗濯();
        }
    }

    //状況
    interface IState {
        void doAction(洗濯機 obj); //何か処理をします
    }
    class 洗い : IState {
        public void doAction(洗濯機 obj) {
            MessageBox.Show("洗いました。");

            obj.setState( new すすぎ() );
        }
    }
    class すすぎ : IState {
        public void doAction(洗濯機 obj) {
            MessageBox.Show("すすぎました。");

            obj.setState( new 脱水() );
        }
    }
    class 脱水 : IState {
        public void doAction(洗濯機 obj) {
            MessageBox.Show("脱水しました。");

            obj.setState( new 乾燥() );
        }
    }
    class 乾燥 : IState {
        public void doAction(洗濯機 obj) {
            MessageBox.Show("乾燥しました。");

            obj.setState( null );
        }
    }

    class 洗濯機 {
        IState 状況 = null;
        public void setState(IState obj) {
            状況 = obj;
        }

        public void 洗濯() {
            状況 = new 洗い();

            while (状況 != null) {
                状況.doAction(this);
            }

            MessageBox.Show("終わりました。");
        }
    }
}

YouTube X

新着一覧

  • async、awaitJavaScript
  • Promise についてJavaScript
  • パッケージの管理Node.js
  • v-model(双方向バインディング)Vue.js
  • VS Code で GitHub を使ったソース管理Git
  • computed(再計算)Vue.js
  • watchDebounced(値の監視)Vue.js
  • watch(値の監視)Vue.js
  • change イベントVue.js
  • v-memoVue.js

アーカイブ

  • 2026/03
  • 2026/02
  • 2026/01
  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08
  • /00

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲