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

第102回 Decoratorパターンについて

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

1. 概要

独り言によるプログラミング講座「第102回 Decoratorパターンについて」です。
デザインパターンの1つである Decorator パターンについて説明しています。
Decorator パターンは、I/Fを変更せずに機能を変更するのが目的です。
これに対し、Adapter パターン、Proxy パターンは、基本的には機能を変更しません。
目的が異なるだけで、実装の考え方は同じです。

2. 動画



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

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

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

            //■Decoratorパターンについて
            //  継承を使わずに機能拡張(継承)するパターン
            //  Proxyとほぼ同じ。
        }

        private void button1_Click(object sender, EventArgs e)
        {
            //ITest obj = new TestA();
            ITest obj = new TestB(new TestA());

            obj = new TestC(obj);

            //ここの処理は変わらない
            MessageBox.Show(obj.getValue().ToString());


        }
    }

    interface ITest {
        int getValue();
    }

    class TestA : ITest {
        public int getValue() {
            return 100;
        }
    }

    //通常継承
    class TestAEx : TestA {}

    class TestB : ITest {
        ITest objTest = null;

        //コンストラクタ
        public TestB(ITest obj) {
            objTest = obj; //内部で保持する
        }

        public int getValue() {
            return (int)(objTest.getValue() * 1.08);
        }
    }

    class TestC : ITest {
        ITest objTest = null;

        //コンストラクタ
        public TestC(ITest obj) {
            objTest = obj; //内部で保持する
        }

        public int getValue() {
            return (int)(objTest.getValue() / 1.08);
        }
    }
}

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.

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