No.1ベストアンサー
- 回答日時:
「委譲」とは、他のオブジェクトに処理(責任)を譲ることをいいます。
多分、ソースを見比べると雰囲気が分かります。
クラス C のメソッド print() を、頭に「★」を付加するように拡張する例です。
class C {
public:
void print(char* str) { cout << str << endl; }
};
//継承で機能拡張
class C1 : public C {
public:
void print(char* str) {
cout << "★";
C::print(str);
}
};
//委譲で機能拡張
class C2 {
private:
C* c_;
public:
C2() { c_ = new C(); }
void print(char* str) {
cout << "★";
c_->print(str);
}
}
大変解かり易い例をあげていただき、ありがとうございます。
なるほど、特別な機能という訳ではないのですね。(^^;
・・・ただ、やってることは理解できたのですが、
なぜ継承よりも委譲の方が良いとされるのでしょうか?
やはり、ソースの見通しが良いとかそういう理由なのでしょうか。
追加の質問で申し訳ありません。
No.2
- 回答日時:
委譲…譲り渡すこと
禅譲…徳のあるもの、有能な者に位を譲ること
禅譲??
『安易な継承(世襲)でなく『禅譲』を使うほうが良い…』なら意味がわかりますが。
具体的にはどんな分野・場面で使われていたのでしょうか?(もしかして本物のプログラム用語なのでしたら、一笑にふしてください。←まったくの素人なので勘違いかもしれんです。)
No.3
- 回答日時:
> なぜ継承よりも委譲の方が良いとされるのでしょうか?
オブジェクト指向というのは、要求される「機能」を実装してゆくのではなく、対象と
している問題領域を *素直に* モデル化することで、それが要求される機能の変更に
対して強い(変更箇所が局所化されている)のが利点だ、というのは本で読んだとおりです。
その「素直なモデル化」に関係することです。
派生というのは、is-a の関係にある関連です。
継承元→継承先と見ると、それは「具体化」になっているべきで、逆に、継承先→継承元と
見ると、「抽象化」になっているべきです。概念として包含関係になっているように。
例えば、動物→哺乳類→猿、というふうに概念が具体的になってゆきます。
猿から派生させるとしたら、猿を更に具体化するような、ゴリラだとかチンパンジーは
OK なんですけど、求める振る舞い(機能と言っても良い)が、殆ど同じだからといって
猿から犬を派生させちゃいけないんです。
これは「安直な派生」とみなされます。
ただ、現実問題として、同じ振る舞いをあちこちに記述するのは、オブジェクト指向が
求めるものからいっても、ふさわしいことではないですから、そういった場合の解決
方法として「委譲」の方が良いのではないか、ということです。
さっきの犬の話に戻ると、具体化のレベルを合せる意味では、犬は哺乳類から派生させる
べきで、実装を共有させるために、幾つかのメソッドを猿に委譲する方が、オブジェクト
としては素直なモデルです。
安直な派生のもうひとつのケースとして、多重継承があります。
新しい機能を実装するクラスを考えたときに、あの機能も流用したい、この機能も
流用したい、だから、いろんなクラスから多重継承してしまう、というケース。
これも「機能の実装」の側面で考えているわけですから、派生は概念の具体化だ、と
言うことに反します。
機能を流用したければ、そのオブジェクトを抱えておいて、必要な機能だけを委譲して
使う方が良い、と言われます。
# ん~、あまり上手な説明ではないですね (^^;
# 補足は遠慮無くどうぞ。できる範囲で頑張ります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- 中古バイク 原付の譲渡について 3 2022/03/27 01:22
- レトロゲーム ファイアーエムブレム聖戦の系譜について。セティが仲間になりましたが、エーディンからラナに継承したサイ 1 2022/03/30 19:32
- 分譲マンション 分譲マンション・管理組合の委任状について 3 2023/04/23 23:49
- 政治 立憲泉さんが壊れたロボットみたいになってるけど、大丈夫か? 立憲民主を擁護している方々も多いけど、や 2 2022/10/22 10:46
- 法学 根抵当権分割譲渡登記 債権の範囲について 1 2023/02/06 10:59
- 会社経営 労働基準と事業譲渡に関する質問について教えてください。 1 2023/06/01 19:43
- 会社・職場 完全歩合制の業務委託の立場の人間が、研修中の正社員に仕事を教える(イコール自分の金を正社員に譲り渡す 5 2022/09/06 08:32
- 査定・売却・下取り(車) 車検証の所有者のとこが自動車店になってて、使用者が私の場合で、その車を買取店で手放す時の必要書類は自 2 2023/02/18 07:07
- 投資・株式の税金 一般口座で同一銘柄の総平均法のことで 1 2023/02/27 22:08
- 政治 日本共産党は女性天皇を認めよ言うてます。従って女性天皇を支持する日本人は日本共産党員ですか? 4 2023/03/03 08:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
抽象クラスをJUNITでテストする...
-
抽象クラスからオーバーライド...
-
JavaにListElement型ってあるん...
-
「ラッパークラス」の存在意義...
-
オーバーライドとラッパーの違い
-
C#からDLLを呼びたいのですが・...
-
vb.net 自作プロパティの削除に...
-
(vba)他のアプリケーションの右...
-
setTextについて
-
抽象クラスのエラーが出ます
-
委譲って何ですか?
-
単体テストのテストケースにて...
-
【C#】クラスのコンストラクタ...
-
JavaでのAPIの覚え方ってみさな...
-
オブジェクト指向の特徴
-
JTextFieldの入力制限
-
ASP.NETでの共通コードの書き方...
-
「インターフェイス」って何の...
-
「IOException は対応する try ...
-
Javaのインターフェイスの意味
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
interface,extend,implementの...
-
(vba)他のアプリケーションの右...
-
抽象クラスをJUNITでテストする...
-
「ラッパークラス」の存在意義...
-
ASP.NETでの共通コードの書き方...
-
JTextFieldの入力制限
-
「継承されたメソッドの可視性...
-
C# 「データが失なわれる可能性...
-
VB DLLプロジェクトについて
-
c++でのヘッダーファイルの循環...
-
【C#】クラスのコンストラクタ...
-
「IOException は対応する try ...
-
ファイルパスが取得出来ない(P...
-
メソッドの引数にクラス名を渡す
-
ゲッターを使わないで変数にア...
-
Javaのインスタンス化の構文の...
-
オーバーライドとラッパーの違い
-
vb.net 自作プロパティの削除に...
-
なぜインタフェースを使うのか?
-
VBがオブジェクト指向言語でな...
おすすめ情報