設定より規約
[Wikipedia|▼Menu]
.mw-parser-output .ambox{border:1px solid #a2a9b1;border-left:10px solid #36c;background-color:#fbfbfb;box-sizing:border-box}.mw-parser-output .ambox+link+.ambox,.mw-parser-output .ambox+link+style+.ambox,.mw-parser-output .ambox+link+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+style+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+link+.ambox{margin-top:-1px}html body.mediawiki .mw-parser-output .ambox.mbox-small-left{margin:4px 1em 4px 0;overflow:hidden;width:238px;border-collapse:collapse;font-size:88%;line-height:1.25em}.mw-parser-output .ambox-speedy{border-left:10px solid #b32424;background-color:#fee7e6}.mw-parser-output .ambox-delete{border-left:10px solid #b32424}.mw-parser-output .ambox-content{border-left:10px solid #f28500}.mw-parser-output .ambox-style{border-left:10px solid #fc3}.mw-parser-output .ambox-move{border-left:10px solid #9932cc}.mw-parser-output .ambox-protection{border-left:10px solid #a2a9b1}.mw-parser-output .ambox .mbox-text{border:none;padding:0.25em 0.5em;width:100%;font-size:90%}.mw-parser-output .ambox .mbox-image{border:none;padding:2px 0 2px 0.5em;text-align:center}.mw-parser-output .ambox .mbox-imageright{border:none;padding:2px 0.5em 2px 0;text-align:center}.mw-parser-output .ambox .mbox-empty-cell{border:none;padding:0;width:1px}.mw-parser-output .ambox .mbox-image-div{width:52px}html.client-js body.skin-minerva .mw-parser-output .mbox-text-span{margin-left:23px!important}@media(min-width:720px){.mw-parser-output .ambox{margin:0 10%}}

この記事は検証可能参考文献や出典が全く示されていないか、不十分です。出典を追加して記事の信頼性向上にご協力ください。(このテンプレートの使い方
出典検索?: "設定より規約" ? ニュース ・ 書籍 ・ スカラー ・ CiNii ・ J-STAGE ・ NDL ・ dlib.jp ・ ジャパンサーチ ・ TWL(2019年9月)

設定より規約(せっていよりきやく、: convention over configuration; CoC)とは、開発者の決定すべきことを減少させ、単純にするが柔軟性は失わせないソフトウェア設計パラダイム

この言葉の本質的な意味は、開発者が指定しなければならないのはアプリケーションの慣例に従わない点だけだ、ということである。例えば、モデルの中にSalesというクラスがあれば、データベース中の対応する表の名前はデフォルトでsalesである、という規約を定める。この規約から逸脱するときだけ、例えばその表を "products_sold" という名前にする場合だけ、その名前を使ったコードを書く必要が生じる。

使用しているツールが実装した規約が開発者の望む動作と一致していれば、設定ファイルを書く必要もない。実装規約と望みの動作が違っている場合だけ、必要な動作を設定すればよい。
背景

従来のソフトウェアフレームワークには、複数の設定ファイルを持ちまたそれぞれに多数の設定項目が存在するものがあった。これらはプロジェクト固有の情報を定義するためのもので、URLからクラス - データベーステーブル間のマッピングに至るまで、多岐に渡る情報が含まれた。大量の設定ファイルがまたそれぞれ大量の設定項目を有するという状況は、アプリケーションの設計が過度に複雑であることを示す場合が少なくない。

例えば、Javaの永続性マッパーとして有名なHibernateの初期バージョンでは、クラス実体(エンティティ)のフィールドとデータベーステーブル間のマッピングをXMLファイルで記述していた。@media screen{.mw-parser-output .fix-domain{border-bottom:dashed 1px}}ところが、このような情報の大半は、クラス名とデータベーステーブル名を同名とし、フィールド名とカラム名も同名にする、という簡単な規約さえあったならわざわざ定義するまでも無かった筈である[独自研究?]。Hibernateの後のバージョンでは事実この設定用XMLファイルは廃止され、正に今述べた通りの規約が採用された。規約から逸脱せざるを得ない場合はJavaのアノテーションを用いて利用者独自の定義を書けるようになっている。
使用

最近のフレームワークは「設定より規約」アプローチを採用しているものが多い。例えば、Ruby on Rails、Kohana、GrailsGrokZend FrameworkCakePHPSymfony などがある。
外部リンク

Detailed information to CoC


記事の検索
おまかせリスト
▼オプションを表示
ブックマーク登録
mixiチェック!
Twitterに投稿
オプション/リンク一覧
話題のニュース
列車運行情報
暇つぶしWikipedia

Size:6031 Bytes
出典: フリー百科事典『ウィキペディア(Wikipedia)
担当:undef