私は単なるエンジニアであって学者や研究者ではないため、ここに書いてある内容は科学的に吟味されたものではありません。\\ が、普段の仕事の中で気付いた合理性のある内容だと思っています。 !!!オブジェクト指向って? オブジェクト指向の説明として良く出てくるのが、 *隠蔽 *継承 *多態性 というものです。 これらはオブジェクト指向の特徴を確かに言い表していますが、オブジェクト指向的な設計や実装をするための役に立たないとytpは考えています。少なくとも初心者にとっては百害有って一理無しです。 !!クラスを見つけるのがオブジェクト指向設計 オブジェクト指向にはクラスが必要です。オブジェクト指向的に設計しようとすることはクラスを見つけることに他なりません。 !!AクラスとBクラスが異なるクラスとして必要な理由は何? クラスを見つけるというのはつまりクラスを定義することですが、では、AクラスとBクラスという2つの異なるクラスが必要になる時の理由は何でしょうか? #処理が異なる #責務が異なる #データ構造が異なる 正解は「データ構造が異なる」です。\\ クラスの根本は、構造体(データ構造)とそれを扱う処理(関数orメソッド)を一体化させたものです。 次のリンクはSunのJava入門のページですが、そこにある図を参照して下さい。 [What Is an Object?|http://download.oracle.com/javase/tutorial/java/concepts/object.html]\\ Fieldsというのが構造体のことで、その周りをMethods(処理)が取り巻いています。この図は、クラスを基に生成されたオブジェクトの概念を書いたものですが、オブジェクトの設計図となるクラスの定義も同様な考え方です。\\ この図からも解るように、データ構造を持たないクラスはそもそもクラスとして機能しません。クラスの原理に反するからです。\\ ですが、データ構造を持たないクラスをJavaなどの言語では定義出来てしまうため、単なる関数を定義しただけのclassをクラスと勘違いしている設計者/プログラマーが大勢います。 public staticなメソッドのみのクラスがそれです。ユーティリティクラスとも呼ばれます。 !!責務がクラスを決めるのではないのか? クラスは「責務」によって定義されるといくつかの解説書には書いてありますが、これは誤りだと私は考えています。\\ 責務という言葉を言い換えると「しなければならないこと」「出来なければならないこと」となります。クラスを利用する側から見るとそのクラスが何を出来るか(してくれるか)は確かに重要です。\\ ですがそれは使う側から見た場合であって、設計する人はそれだけではクラスを定義出来ません。一つ例を出します。\\ !!「ジュース売り」という責務 「ジュース売り」という責務を考えてみます。\\ ジュース売りがしなければならないことは次のような事です。 #注文を聞く #金額を伝える #お金をもらう #品物とお釣りを渡す では、この責務を請け負えるモノは何が考えられるでしょうか?\\ !!ジュース売りを請け負えるモノとは? *人間 *自動販売機 ジュース売りを請け負えるモノとして少なくともこの2つが考えられます。将来的には「ロボット」も入ってくるかもしれません。\\ つまり責務が決まったからと言ってそのモノまでは決められないのです。\\ これは当然で、「何が出来るのか」というのは処理の規定であって、データ構造つまりそのモノの状態は関係無いからです。\\ Javaなどでは「Interface」として定義するのが責務です。Interfaceはメソッドを規定するだけで中身は実装者任せです。まさに、「責務は決めるがモノは決めない」という機能です。ちなみに私はInterfaceのことを責務ではなく「役割」と呼ぶようにしています。 !!みんななぜ間違うのか? 世間ではクラスと思われているものが実は誤りである。なぜそうなってしまうのでしょうか?\\ クラスを設計する際、その基となるのは顧客からの要求です。要件と呼ばれます。この要件は、「xxxがしたい」「mmmが出来るようになりたい」という実務処理の記述です。言ってしまえば役割を列挙したものです。\\ 役割というのは上で書いたように処理に過ぎません。クラスとして必要なデータ構造はそれだけでは出て来ません。\\ そのため、オブジェクト指向に不慣れな設計者・実装者はその要件(処理)だけを頼りに開発してしまいます。データ構造を考えずに処理だけを追いかけてしまうのです。これが誤りの根本です。 !!まとめ *クラスを規定するのは処理ではなくデータ構造 *責務をクラスにしてはいけない