オブジェクト指向プログラミング (オブジェクトしこうプログラミング、英 : object-oriented programming , OOP)とは、「オブジェクト 」という概念に基づいたプログラミングパラダイム の一つである。
OOPでは、相互に作用するオブジェクトを組み合わせてプログラムを設計する。
OOPの方法として、クラスベース OOPとプロトタイプベース OOPがある。
クラスベースOOPでは、オブジェクトが属する集合としてクラス を定義し、クラス定義からそのインスタンス としてオブジェクトを生成する。
プロトタイプベースOOPでは既存のオブジェクト(プロトタイプ)を複製し、プロトタイプの複製に変更を加えることで様々な対象を表すオブジェクトを生成する。
広く使われているプログラミング言語の多く、例えばC++ やJava やPython などは、マルチパラダイム であるが、程度の差はあれ、オブジェクト指向プログラミングをサポートしており、大抵は命令型 や手続き型プログラミング との組み合わせで用いられる。
歴史
UML によるクラス の表記法。この Button
クラスは、データを表す変数 (図中 xsize
など)と関数 (図中 draw()
など)を持つ。一般的なクラスは継承 によりサブクラス を持つことができる。また、オブジェクトはクラスのインスタンス である。
アラン・ケイ によれば “object-oriented ”(オブジェクト指向 )という言葉は、1967年ごろケイ自身が考案したものであるという。しかし、現在のオブジェクト指向プログラミングという文脈における「オブジェクト」や「指向」を表す用語が初めて登場したのは、1950年代後半から1960年代前半にかけてのマサチューセッツ工科大学(MIT) においてである。
1960年代初頭の人工知能 グループ界隈では、「オブジェクト」はプロパティ(属性)を持つ個体識別可能なアイテム(LISP の atom)を意味していた。
後にケイは、1966年にLISPの内部構造を詳細に理解したことが彼の考え方に強い影響を与えたと述べている。
私は、オブジェクトとは、生物の細胞やネットワーク上の個々のコンピュータのようもの、そしてそれらのコミュニケーションは専らメッセージによって行なわれるもの、と考えていました (つまり、メッセージングは最初から存在していたのですが、プログラミング言語でメッセージングを実用的かつ効率的に行う方法を見つけるまでには時間がかかりました)。
アラン・ケイ, (Meaning 2003 )
MITにおける初期の例としては、この他にも、1960年から1961年にかけてアイバン・サザランド が作成したSketchpad が挙げられる。サザランドは、1963年の技術レポートの用語集 (Sketchpadに関する自身の博士論文をもとにしたもの)で、グラフィカルなインタラクションに特化しているとはいえ「オブジェクト」と「インスタンス」の概念を定義している (クラスの概念は"master"または"definition"として把握されている)。[ 6]
また、MIT版のALGOL であるAED-0では、データ構造 (この言語の方言では"plexes"と呼称)と手続きを直接結びつけ、後に「メッセージ」、「メソッド」、「メンバ関数」と呼ばれるようなものの萌芽がみられる。
1962年、クリステン・ニゴール はノルウェー計算センター (英語版 ) でシミュレーション言語のプロジェクトを開始した。これは彼が以前に用いたモンテカルロ法 と実世界のシステムを概念化する仕事に基づくものであった。オーレ=ヨハン・ダール が正式にプロジェクトに参加し、UNIVAC I (UNIVAC 1107) 上で動作するSimula プログラミング言語が設計された。Simulaは、クラス やオブジェクト 、継承、ダイナミックバインディング など、今日のオブジェクト指向プログラミングには不可欠である重要な概念を導入した。
Simulaはまた、プログラミングにおけるデータ保全 (英語版 ) を考慮して設計されたものでもあった。プログラミングのデータ保全のために参照カウント による検出プロセスが実装されたのに加え、最終手段としてガベージコレクタ が主記憶装置 (メモリ)内の使用されていないオブジェクトを削除するようになっていた。しかし、データオブジェクトの概念は1965年には既に確立されていたものの、プライベートやパブリックといった変数 のスコープ のレベルによるデータのカプセル化については、アクセスする手続きもまた隠蔽できなければならなかったため、Simulaでは実装されなかった。
初期の段階では、Simulaはプログラミング言語ALGOL 60のための手続きパッケージとされていた。しかし、ALGOLによる制約に不満を感じた研究者たちは、UNIVAC ALGOL 60コンパイラを使用した本格的なプログラミング言語としてSimulaを開発することにした。ダールとニゴールは1965年から1966年にかけてSimulaの普及に尽力し、スウェーデン、ドイツ、ソビエト連邦 などでSimulaの使用が増加した。1968年には、バロース B5000 上で広く利用されるようになり、後にはURAL-16コンピュータ 上にも実装された。1966年、ダールとニゴールはSimulaのコンパイラ を書いた。彼らは、SIMSCRIPT (英語版 ) (自由形式の英語的な汎用シミュレーション言語)を実装に用いて、アントニー・ホーア のレコード・クラス概念を取り入れることに熱心に取り組んだが、彼らは、一般化されたプロセスの概念として、レコード・クラスの属性を保持する層と、接頭辞 (prefix) の系列を保持する層の二層構造とする方式に辿り着いた。
接頭辞の系列を通じて、プロセスは先行する定義を参照し、それらの属性を追加することができる。このようにしてSimulaは、クラスとサブクラスの階層を導入し、これらのクラスからオブジェクトを生成することを可能にする方法を導入することとなった。
1972年にはIBM System/360 およびIBM System/370 のIBMメインフレーム 用にSimula 67コンパイラが完成。同年、フランスのCII 10070 およびCII Iris 80メインフレーム 用のSimula 67コンパイラが無償で提供された。1974年には、Simulaユーザー会は23カ国のメンバーを有するまでになっていた。1975年初頭、DECsystem-10 メインフレームファミリー用のSimula 67コンパイラが無償でリリースされ、同年8月までにDECsystem-10のSimula 67コンパイラは28サイトにインストールされた (そのうちの22サイトは北米)。オブジェクト指向のプログラミング言語としてSimulaは、貨物港における船舶と積載貨物の動きを調査・改善するための研究のような、物理モデリングの研究に携わる研究者に主に利用されていた。
1970年代、Xerox パロアルト研究所(PARC) において、アラン・ケイ 、ダン・インガルス 、アデル・ゴールドバーグ らによって、プログラミング言語Smalltalk の最初のバージョンが開発された。Smaltalk-72はプログラミング環境を含み、動的型付け であり、当初はコンパイル してからの実行ではなくインタプリタ 実行であった。Smalltalkは、言語レベルでのオブジェクト指向の適用と、グラフィカルな開発環境で注目されたが、Smalltalkが様々なバージョンを経て成長するにつれ、この言語への関心も高まっていった。
SmalltalkはSimula 67で導入されたアイデアの影響を受けてはいるものの、クラスを動的に生成・変更できるなど、完全に動的なシステムとして設計された。
1970年代、SmalltalkはLispコミュニティ に影響を与え、Lispコミュニティは、Lispマシン を通じて開発者に紹介されたオブジェクトベースの技術を取り入れた。Lispの様々な拡張機能(LOOPS やFlavors (英語版 ) などが導入した多重継承 やMixin )の試みは、最終的に関数型プログラミング とオブジェクト指向プログラミングを統合し、メタオブジェクト・プロトコル (英語版 ) による拡張を可能にしたCommon Lispのオブジェクト指向システム (CLOS) へとつながった。
1980年代には、メモリ上のオブジェクトをハードウェアでサポートするプロセッサ・アーキテクチャを設計する試みがいくつか行われたが、Intel iAPX 432 やLinn Smart 、Rekursiv (英語版 ) など、いずれも商業的に成功しなかった。
1981年、ゴールドバーグはByte Magazine 8月号のSmalltalk特集号で、Smalltalkとオブジェクト指向プログラミングをより多くの人々に紹介した。
1986年、ACM が主催する第一回OOPSLA が開催され、予想に反して1,000人が参加した。1980年代半ばには、ITT でSmalltalkを使っていたブラッド・コックス によってObjective-C が開発され、博士論文でSimulaを扱っていたビャーネ・ストロヴストルップ よってオブジェクト指向のC++ が作られた。
1985年には、バートランド・メイヤー もEiffel の最初の設計を行った。ソフトウェアの品質に焦点を当てたEiffelは、純粋なオブジェクト指向プログラミング言語であり、ソフトウェアのライフサイクル全体をサポートする記法をもつ。メイヤーは、ソフトウェア工学とコンピュータサイエンスの少数の重要なアイデアに基づいたEiffelでのソフトウェア開発手法をオブジェクト指向入門 (英語版 ) で解説している。Eiffelでは、メイヤーが開発した信頼性担保の機構である契約プログラミング が、開発手法と言語の双方に不可欠な要素となっている。
TIOBE プログラミング言語の人気ランキング の2002年から2018年のグラフ。2000年代のオブジェクト指向言語Java (青)と手続き型プログラミング 言語C (黒)の首位争いの様子
1990年代前半から半ばにかけて、オブジェクト指向プログラミングは、その技術をサポートするプログラミング言語が広く普及したことにより、プログラミングパラダイム として主要なものとなった。その中には、Visual FoxPro 3.0[ 注 1] [ 12] [ 13] 、C++ [ 14] 、Delphi [ 15] などがある。
その勢力は、オブジェクト指向プログラミング技術に支えられたグラフィカルユーザインタフェース の人気向上と共に高まった。動的なGUIライブラリとOOP言語が密接に連携している例としては、Smalltalkを規範にしたCのオブジェクト指向の動的メッセージング拡張であるObjective-C で書かれたmacOS のCocoa フレームワークなどが挙げられる。また、OOPツールキットの存在は、イベント駆動型プログラミング の人気を高めることにも繋がった(ただし、この概念はOOPに限定されるものではない)。
チューリッヒ工科大学 では、ニクラウス・ヴィルト らが、データ抽象化 やモジュール化プログラミング (英語版 ) などの研究を行っていた (ただし、これらは1960年代以前にも一般的に使われてはいた)。
1978年に発表されたModula-2 にはこの2つが盛り込まれており、その後に発表されたOberon では、オブジェクト指向やクラスなどに対する独自のアプローチが盛り込まれている[ 16] 。
オブジェクト指向の機能は、Ada 、BASIC 、Fortran 、Pascal 、COBOL など、既存の多くの言語に追加されていったが、しかし、設計当初にこれらの機能を想定していなかった言語に追加した場合、コードの互換性や保守性には問題が生じることが多かった。
最近では、主としてオブジェクト指向でありながら、手続き型プログラミングの方法論にも対応した言語が数多く登場している。そのような言語としては、Python やRuby がある。最近の商業的なオブジェクト指向言語で最も重要なものには、サン・マイクロシステムズ 社が開発したJava や、Microsoftの.NET プラットフォーム用に設計されたC# 、Visual Basic .NET (VB.NET) が挙げられる。
これら二つのフレームワークは、実装を抽象化することによるOOP使用の利点をそれぞれの方法で示している。VB.NETとC#間では言語間継承をサポートしており、一方の言語で定義されたクラスが他方の言語で定義されたクラスをサブクラス化することができる[ 17] 。
OOPLの特徴
オブジェクト指向プログラミング言語 (OOPL ) では、オブジェクトを使用するが、言語仕様でOOP対応を謳っていても、関連する技術や構造のすべてが言語機能により直接サポートされているわけではない。以下に挙げる特徴は、特に言及されている例外を除いて、クラス指向やオブジェクト指向の傾向が強いとされる言語 (あるいはOOPをサポートするマルチパラダイムプログラミング言語 )に共通すると考えられるものである。
非OOPLとの共通点
変数
整数型 や英数字の文字 のような形式化された少数の組み込みデータ型 の情報、または、文字列 、リスト 、ハッシュテーブル などのデータ構造 に、組み込み型もしくは、ポインタ が格納されたものを結果として格納することができる。
手続き(関数、メソッド、サブルーチン とも呼ばれる)
入力を受け取り、出力を生成し、データを操作する。近年の言語には、ループ や条件構文 のような構造化プログラミング の構成要素が含まれる。
モジュラープログラミング サポートでは、手続きをファイルやモジュールにまとめて整理する機能がある。モジュールは名前空間 を持つため、あるモジュールの識別子が、他のモジュールの同名の手続きや変数と衝突することを避けることができる。
クラスとオブジェクト
オブジェクト指向プログラミング(OOP)をサポートする言語は、コードの再利用と拡張性のために、典型的には、クラス またはプロトタイプ の形で継承 を使用する。クラスを使用するものは、主に二つの概念をサポートする。
クラス
与えられた型やクラスのオブジェクトのデータ形式やそれらを利用可能な手続きの定義であり、また、データや手続き (クラスメソッドとも呼ばれる)そのものを含む場合もある。つまり、クラスは、メンバーとなるデータや手続きを含むものである。
オブジェクト
クラスのインスタンス
オブジェクトは、システムが扱おうとする(多くは現実世界の)対象を表現したものである。例えば、描画アプリケーションにおける「円」・「四角」・「メニュー」などのオブジェクトや、オンラインショッピングシステムにおける「ショッピングカート」・「顧客」・「商品」などのオブジェクトがある[ 18] 。
オブジェクトは、ファイルのオープンを表すオブジェクトや、米国慣用単位 からメートル法 に変換するサービスを提供するオブジェクトのように、より抽象的なエンティティを表すこともある。
オブジェクト指向プログラミングとは、単なるクラスやオブジェクトではなく、データフィールドやメソッドを含んだオブジェクト (データ構造)を中心としたプログラミングパラダイム全般のことです。クラスを使って、関係のないメソッドをまとめて整理する——これがオブジェクト指向の本質ではないことを理解しましょう。
Junade Ali, Mastering PHP Design Patterns (Ali 2016 , p. 11)
各々のオブジェクトは、特定のクラスのインスタンス と呼ばれる (例えば、name
フィールドに "Mary"
が設定されているオブジェクトは、クラスEmployee
のインスタンスとなる)。OOPの手続きはメソッド と呼ばれ、変数は、フィールド 、メンバー、属性、プロパティとも呼ばれる。関連して、以下のような用語がある
クラス変数
クラス自体に属する。変数をクラス全体に唯一のものとして所有する。
インスタンス変数 または属性
各々のオブジェクトに属する。データはオブジェクトごとに所有する。
メンバ変数
特定のクラスで定義されるクラス変数とインスタンス変数の両方を指す。
クラスメソッド
クラス自体に属する。クラス変数へのアクセスのみ有し、手続き呼び出しからの入力のみ受け付ける。
インスタンスメソッド
各々のオブジェクトに対して、呼び出された特定のオブジェクトのインスタンス変数、入力、およびクラス変数にアクセスできる。
オブジェクトは、複雑な内部構造を持った変数のようにアクセスされるが、多くの言語で実質的にはポインタ でありインスタンス (ヒープやスタック内のメモリ上オブジェクト)への参照として機能する。オブジェクトは、内部コードと外部コードを分離を可能とする抽象化 の層を提供する。外部のコードは、特定の入力引数の組み合わせで特定のインスタンスメソッドを呼び出したり、インスタンス変数を読み込んだり、インスタンス変数に書き込んだりすることで、オブジェクトを使用することができる。オブジェクトは、コンストラクタ と呼ばれるクラス内の特定メソッドを呼び出すことで生成される。プログラムは実行中に、それぞれ独立して操作することが可能な同じクラスのインスタンスを多数作成することができる。これは、同じ手続きを異なるデータセットで簡便に利用する方法となる。
クラスを使用するOOPをクラスベース ・プログラミングと呼ぶことがあるが、プロトタイプベース ・プログラミングではクラスを使用しないのが一般的である。そのため、オブジェクト とインスタンス という概念の定義は、それぞれで大きく異なるが類似した用語が用いられている。
言語によっては、トレイト やmixin のような概念を用いてクラスやオブジェクトを構成することが可能である。
クラスベース対プロトタイプベース
クラスベースの言語 では、予めクラス が定義され、そのクラスに基づいてオブジェクト がインスタンス化される。例えば、apple とorange という2つのオブジェクトが、Fruit というクラスからインスタンス化された場合、それらは本質的には果物であり、同じように取り扱えることの保証がされる。
プロトタイプベースの言語 では、オブジェクト が主要な実体である。クラス は存在しない。オブジェクトのプロトタイプ とは、あるオブジェクトからリンクされている別のオブジェクトに過ぎない。すべてのオブジェクトは一つのプロトタイプ リンクを持つ (一つのみ)。新しいオブジェクトは、プロトタイプとして選ばれた既存のオブジェクトに基づいて作成することができる。fruit オブジェクトが存在し、apple とorange の両方がfruit をプロトタイプとしている場合、2つの異なるオブジェクトapple とorange を果物と考えることができる。fruit 「クラス」という概念は明示的には存在しないが、同じプロトタイプを共有するオブジェクトの同値クラス としては存在する。プロトタイプ の属性やメソッドは、このプロトタイプで定義された同値クラスのすべてのオブジェクトから委譲 先とされる。オブジェクト固有の属性やメソッドは、同値クラスの他のオブジェクトに共有されない場合がある。例えば、属性sugar_content はapple には予期せず存在しない場合がある。プロトタイプで実装できるのは単一継承 のみである。
動的ディスパッチとメッセージパッシング
メソッドの呼び出しに応じて実行する手続きのコードを選択するのは、外在するコードではなく、オブジェクトの責任である。典型的には、オブジェクトに関連付けられたテーブルから実行時にメソッドを検索するが、この機能は動的ディスパッチ として知られており、抽象データ型 (またはモジュール)において、すべてのインスタンスの操作が静的に実装されているのとは対照的である。呼び出しの変化が、呼び出されたオブジェクトの単一の型にのみには依らない場合 (つまり複数のオブジェクトがメソッド選択に関与する場合)、多重ディスパッチ と呼ばれる。
メソッド呼び出しは、メッセージパッシング とも呼ばれる。これは、メソッド呼び出しを、ディスパッチのためにオブジェクトに渡されるメッセージ (メソッドの名前とその入力引数)として概念化したものである。
カプセル化
カプセル化 とは、オブジェクト指向プログラミングにおいて、データとそのデータを操作する関数を結び付け、両者を外部からの干渉や誤用から守ることである。データのカプセル化は、OOPの重要な概念である情報隠蔽 (英語版 ) にも通じる。
クラスがメソッドを通じてのみオブジェクトの内部データへのアクセスを許可し、それ以外の呼び出しコードにアクセスを許可しない場合、これはカプセル化として知られる強力な抽象化、または情報隠蔽の形態である。いくつかの言語 (Javaなど)では、クラスがアクセス制限を明示的に行うことができる。例えば、内部データであることをprivate
というキーワードで指定し、クラス外のコードが使用することを意図したメソッドをpublic
というキーワードで指定することができる。また、メソッドはpublic、private、またはprotected
(同クラスとそのサブクラスからのアクセスは許可するが、異なるクラスのオブジェクトからのアクセスは許可しない)のように中間のアクセスレベルとすることもできる。また他の言語 (Pythonなど)では、アクセス制限は、命名法などの慣例によってのみ強制される (例えば、private
のメソッドはアンダースコア で始まる名前を持つ、など)。カプセル化することで、外部のコードがオブジェクトの内部動作に関与してしまうことを防ぐことができ、リファクタリング を容易にする。例えば、クラスの設計者は、外部のコードは変更することなく、そのクラスのオブジェクト内部のデータ表現を変更することができる (公開されているメソッドの呼び出しが同じように動作する限りにおいて)。また、特定のデータに関連するすべてのコードを同じクラスに配置することで、他のプログラマが理解しやすいように整理することもできる。カプセル化は、疎結合 を促進する技術である。
コンポジション、継承、委譲
オブジェクトは、そのインスタンス変数に他のオブジェクトを含めることができ、これをオブジェクトコンポジション と呼ぶ。例えば、"従業員"クラスのオブジェクトは、"名前" や "役職"といった自身のインスタンス変数に加えて、"住所"クラスのオブジェクトを (直接またはポインタを介して)含むことができる。
オブジェクトコンポジションは、"has-a" の関係を表現するために使用できる。例えば、すべての従業員は住所を持っているので、すべての"従業員"オブジェクトは、"住所"オブジェクトを格納する場所 (オブジェクトに直接埋め込まれていることも、ポインターで指定された別の場所に格納されることもある)にアクセスできる。
クラスをサポートする言語は、大抵は継承 をサポートしている。継承とは、クラスを「○○は△△である」という関係("is-a-type-of")の階層に配置することであるが、例えば、Employee
クラスは Person
クラスを継承する場合、親クラスで利用できるデータやメソッドは、子クラスでも同じ名前で利用可能である。また、Person
クラスは、first_name
と last_name
という変数を make_full_name()
というメソッドで定義した場合、これらの定義はEmployee
クラスでも利用可能である。加えて、Employee
クラスには変数 position
と salary
を追加することもできる。この手法では、同じ手続きやデータ定義を簡単に再利用できるだけでなく、現実世界の関係を直感的に反映できる可能性を広げる。開発者は、データベースのテーブルやプログラミングのサブルーチンを扱うのではなく、開発アプリケーションのユーザーがより精通しているドメインのオブジェクトを扱うことができる[ 19] 。
サブクラスはスーパークラスで定義されたメソッドをオーバーライドできる。言語よっては多重継承 が可能だが、多重継承ではオーバーライドの解決は複雑になる可能性がある。また、言語によってはmixin を特別にサポートしているものもあるが、多重継承をサポートする言語では、mixinは単に is-a-type-of の関係を表すことのないクラスの一つである。mixinは典型的には、同一のメソッドを複数のクラスに追加するために使われる。例えば、共通の親クラスを持たないFileReader
クラスとWebPageScraper
クラスに、unicode_to_ascii()
というメソッドを持つUnicodeConversionMixin
クラスを含ませる(mixinする)ことにより共通のメソッドを提供することができる。
抽象クラス は、オブジェクトへインスタンス化することはできない。インスタンス化できる他の具象クラスが継承するためにのみ存在する。Javaでは、final
キーワードを用いて、クラスがサブクラス化されるのを防止できる。
Composition over inheritance の方針は、継承の代わりに合成を使って has-a 関係を実装することを提唱している。例えば、EmployeeクラスはPersonクラスを継承する代わりに、各Employeeオブジェクトの内部にPersonオブジェクトを含めることで、仮にPersonクラスが公開された属性やメソッドを多数持っていても、外部のコードからは隠せるようにする。また、Go のように、継承を全くサポートしていない言語も存在する。
開放/閉鎖原則 は、クラスやメソッドは「拡張に対しては開放的であるが、変更に対しては閉鎖的であるべき」という原則を提唱している。
委譲 もまた、継承の代わりに利用できる言語機能である。
ポリモーフィズム
サブタイピング (ポリモーフィズム の一形態)では、呼び出すコードが、サポートされている階層のどのクラスを操作しているのか (親クラスなのかその子孫なのか)という詳細には関知しないことが可能である。一方、継承階層内のオブジェクト間では、同じ操作名でも挙動が異なる場合がある。
例えば、Circle型とSquare型のオブジェクトが、Shapeという共通のクラスから派生している場合、Shapeの各型のDraw関数は、それぞれの描画に必要な機能を実装しているが、呼び出しのコードは、描画されるShapeが特定の型であるかどうかには無関心でいられる。
これもまた、クラス階層からコードを引き離して単純化し、強力な関心の分離 を可能にする抽象化の一種である。
オープンな再帰
オープンな再帰 [ 20] をサポートする言語では、オブジェクトのメソッドは同じオブジェクト上の他のメソッドや自分自身を呼び出すことができる。通常はthis
やself
と呼ばれる特別な変数やキーワードを使用して呼び出しをするのが一般的であるが、この変数は「遅延結合 」であり、あるクラスで定義されたメソッドが、そのサブクラスで後から定義された別のメソッドを呼び出すことができる。
デザインパターン
継承とBehavioral subtyping
継承は意味論 的には is-a の関係を作るため、サブクラスからインスタンス化されたオブジェクトは、スーパークラスからインスタンス化されたオブジェクトの代わりに、常に安全に 使用できる、と推測するのは直感的ではあるが、この直観は、ほとんどのOOPL、特にミュータブル なオブジェクトを許可している言語では誤りである。 (ミュータブルなオブジェクトを持つ)OOPLの型検査器によって強制される部分型付け (部分型多相/サブタイピング多相) では、いかなる状況でも、振る舞いにおける部分型付け (Behavioral subtyping ) は保証することはできない。 Behavioral subtyping は一般に決定不能であり、プログラム (コンパイラ)では実装できない。クラスやオブジェクトの階層は、文法間違いでは検出できない使い方がされる可能性を考慮に入れて、慎重に設計する必要がある。この問題はリスコフの置換原則 としても知られている。
GoFデザインパターン
オブジェクト指向とデータベース
OOPL と関係データベース管理システム (RDBMS) は、どちらも今日[update] のソフトウェアとして非常に一般的であるが、双方を接続する場合、関係データベース は、オブジェクトを直接格納しないため (ただし、今日ではこれに近しい拡張機能を持つ RDBMS も存在する)、この二つの世界を橋渡しすることが一般的な需要として擡頭した。アクセス方法やデータパターンを OOPL と RDB との間で橋渡しする際の問題は、オブジェクト-リレーションのインピーダンスミスマッチ と呼ばれている。
この問題に対処するためのアプローチはいくつかある。欠点のない一般的な解決策といえるものはない[ 21] が、代表的なものとして、オブジェクト関係マッピング (ORM)があり、Visual FoxPro などのIDE 言語や、Java Data Objects、Ruby on Rails のActive Record などのライブラリが存在する。
また、RDBMS を代替するオブジェクトデータベース も存在するが、技術的にも商業的にも RDBMS ほど広く成功は収めていない。
OOPと制御構造
OOPは、ソースコードのコードの再利用性 やソフトウェアの保守性 を高めるよう発展してきたが[ 22] 、ある時期までは制御フロー の透過的な表現については、あまり省みられることもなく、コンパイラが任意に処理すれば良いと考えられてきた。しかし、OOPでの実現にはある種の困難を伴うものの、並列ハードウェアやマルチスレッドコーディング の重要性が増すにつれ透過的な制御フローの開発は重要になってきている[ 23] [ 24] [ 25] [ 26] 。
責任駆動設計 対 データ駆動設計
責任駆動設計 では、クラスは、共有する情報とそれを扱う責務という観点から定義されるべきであるとし、クラス定義 (とその利用者)の契約として設計する。Wirfs-BrockとWilkersonは、責任駆動設計と対比して、データ駆動設計 は、クラスが保持すべきデータ構造のみを中心に定義されるとし、責任駆動型の設計が望ましいとしている[ 27] 。
SOLID、GRASPのガイドライン
SOLID のガイドラインは、プログラミングにおける五つの実践の頭文字をとった語呂合わせであり、マイケル・C・フェザーズ[ 28] が考案し提唱したものである
GRASP (General Responsibility Assignment Software Patterns)は、クレーグ・ラーマン が提唱したもう一つガイドラインである。
形式意味論
脚注
注釈
^ 1995年6月 Visual FoxPro 3.0, FoxPro は手続き型言語からオブジェクト指向言語へと進化した。Visual FoxPro 3.0では、データベースコンテナ、シームレスなクライアント/サーバー機能、ActiveXのサポート、OLEオートメーションとヌルのサポートが導入された。Summary of Fox releases
出典
^ Sutherland 1963 .
^ FoxProの歴史: Foxprohistory.org
^ 1995年のVisual FoxPro 3.0 レビュー/ガイド: DFpug.de
^ Khurana, Rohit (1 November 2009). Object Oriented Programming with C++, 1E . ISBN 978-81-259-2532-3 . https://books.google.com/books?id=MHmqfSBTXsAC&pg=PA16
^ マイナビTECH+: Delphiがトップ20位から脱落: 「Delphiは2001年6月にトップ20位入りを果たし、2000年代初頭には最も人気のある統合開発環境として広く使用されていた。」[1]
^ Wirth, Niklaus. From Modula to Oberon and the programming language Oberon (Report). ETH Technical Reports D-INFK. Vol. Band 82. Wiley.
^ 共通型システム|Microsoft Docs [2]
^ Booch, Grady (1986). Software Engineering with Ada . Addison Wesley. p. 220. ISBN 978-0-8053-0608-8 . https://en.wikiquote.org/wiki/Grady_Booch . "Perhaps the greatest strength of an object-oriented approach to development is that it offers a mechanism that captures a model of the real world."
^ Jacobsen, Ivar; Magnus Christerson; Patrik Jonsson; Gunnar Overgaard (1992). Object Oriented Software Engineering . Addison-Wesley ACM Press. pp. 43–69 . ISBN 978-0-201-54435-0 . https://archive.org/details/objectorientedso00jaco/page/43
^ 『型システム入門』オーム社、2013年、185頁。 18.10 selfを介したオープンな再帰
^ Neward, Ted (26 June 2006). “The Vietnam of Computer Science ”. Interoperability Happens. 4 July 2006時点のオリジナル よりアーカイブ。2 June 2010 閲覧。
^ Ambler, Scott (1 January 1998). “A Realistic Look at Object-Oriented Reuse ”. drdobbs.com. 4 July 2010 閲覧。
^ Shelly, Asaf (22 August 2008). “Flaws of Object Oriented Modeling ”. Intel Software Network. 4 July 2010 閲覧。
^ James, Justin (1 October 2007). “Multithreading is a verb not a noun ”. techrepublic.com. 10 October 2007時点のオリジナル よりアーカイブ。4 July 2010 閲覧。
^ Shelly, Asaf (22 August 2008). “HOW TO: Multicore Programming (Multiprocessing) Visual C++ Class Design Guidelines, Member Functions ”. support.microsoft.com. 4 July 2010 閲覧。
^ Robert Harper (17 April 2011). “Some thoughts on teaching FP ”. Existential Type Blog. 5 December 2011 閲覧。
^ Wirfs-Brock, Rebecca; Wilkerson, Brian (1989). “Object-Oriented Design: A Responsibility-Driven Approach”. ACM SIGPLAN Notices 24 (10): 74. doi :10.1145/74878.74885 .
^ https://wiki.c2.com/?MichaelFeathers
出典
Kindler, E.; Krivy, I. (2011). Object-Oriented Simulation of systems with sophisticated control . International Journal of General Systems. pp. 313–343.
Lewis, John; Loftus, William (2008). Java Software Solutions Foundations of Programming Design (6th ed.). Pearson Education Inc.. ISBN 978-0-321-53205-3
Kay, Alan; Ram, Stefan (23 July 2003). "Dr. Alan Kay on the Meaning of "Object-Oriented Programming" " . www.purl.org . 2022年8月15日閲覧 。
McCarthy, J.; Brayton, R. ; Edwards, D. ; Fox, P. ; Hodes, L. ; Luckham, D. ; Maling, K. ; Park, D. et al. (March 1960). LISP I Programmers Manual . ボストン , マサチューセッツ : Artificial Intelligence Group, en:M.I.T. Computation Center and Research Laboratory. p. 88f. オリジナル の17 July 2010時点におけるアーカイブ。. https://web.archive.org/web/20100717111134/http://history.siam.org/sup/Fox_1960_LISP.pdf . "In the local M.I.T. patois, association lists [of atomic symbols] are also referred to as "property lists", and atomic symbols are sometimes called "objects"."
McCarthy, John ; Abrahams, Paul W.; Edwards, Daniel J. ; Hart, swapnil d.; Levin, Michael I. (1962). LISP 1.5 Programmer's Manual . en:MIT Press . p. 105 . ISBN 978-0-262-13011-0 . https://archive.org/details/lisp15programmer00john/page/105 . "Object — a synonym for atomic symbol"
Sutherland, I. E. (1963年1月30日). “Sketchpad: A Man-Machine Graphical Communication System ”. Technical Report No. 296, Lincoln Laboratory, Massachusetts Institute of Technology via Defense Technical Information Center (stinet.dtic.mil). 17 July 2019 閲覧。
Ali, Junade (2016-09-28) (英語). Mastering PHP Design Patterns (1 ed.). Birmingham, England, UK: Packt Publishing Limited. ISBN 978-1-78588-713-0
Nygaard, Kristen; Dahl, Ole-Johan (1978-08-01). “Development of the SIMULA languages”. ACM SIGPLAN Notices (Association for Computing Machinery) 13 (8): 245–272. doi :10.1145/960118.808391 .
Dahl, Ole Johan (2004). “The Birth of Object Orientation: The Simula Languages” . From Object-Orientation to Formal Methods . Lecture Notes in Computer Science. 2635 . pp. 15–25. doi :10.1007/978-3-540-39993-3_3 . ISBN 978-3-540-21366-6 . http://www.mn.uio.no/ifi/english/about/ole-johan-dahl/bibliography/the-birth-of-object-orientation-the-simula-languages.pdf 22 October 2021 閲覧。 .
Kay, Alan (1993-03-01). “The Early History of Smalltalk”. ACM SIGPLAN Notices (Association for Computing Machinery) 28 (3): 69–95. doi :10.1145/155360.155364 .
Holmevik, Jan Rune (1994). “Compiling Simula: A historical study of technological genesis”. IEEE Annals of the History of Computing 16 (4): 25–37. doi :10.1109/85.329756 .
Meyer, Bertrand (2009). Touch of Class: Learning to Program Well with Objects and Contracts . Springer Science & Business Media. pp. 329. Bibcode : 2009tclp.book.....M . ISBN 978-3-540-92144-8
関連項目
システム
モデリング言語