餃子を食べるとき、何をつけますか?

プラグイン、ライブラリ、コンポーネント、モジュールの違いは?
プログラムを行っている人にとっては初歩的な質問かと思いますが、プログラム開発で出てくるプラグイン、ライブラリ、コンポーネント、モジュールのそれぞれの違いってなんでしょうか?
いずれも、あるプログラムをまとめたプログラムであると思っているのですが、何をどういう基準で分ければいいのかと疑問に思ってしまいました。
よろしくお願いします。

A 回答 (2件)

実はとても良い質問だと思います。



おそらく、明確に答えられるプログラマはあまりいない (特にコンポーネントとモジュールの違いが) と思います。

順に説明していきましょう。

プラグインはあるソフトウェアを拡張するためのプログラムです。
プラグインは単体では動きません。
プラグインは「ソフトウェアを使用する人間が入れ替え可能なプログラムの一部のこと」と言えるでしょう。

プラグインで最も有名なソフトウェアとして、Mozilla Firefox を挙げます。
このソフトウェアの使用者は、Firefox のプラグインとして、各種拡張を自由に追加・入れ替え・削除が行えます。
(firefox では、「拡張」と例えば Adobe Flash Player のようなファイルの種類に応じて呼び出される別のプログラムという2種類のプラグインが存在しているので、注意してください)


ライブラリは有用で汎用性の高い関数・クラス・その他を再利用可能な形でひとまとめにしたものです。
たいていの場合、ライブラリ単体では動きません。
プラグインとの違いは汎用性が挙げられます。
あるソフトウェアを対象として書かれたプラグインと違い、ライブラリは特定のソフトウェアを対象としてかかれていません。

誤解が生じかねないので具体例を挙げます。
例えば、Windows Media Player で YouTube を見られるようにするためのプログラムを書いた場合、それは Windows Media Player のプラグインと言えるでしょう。
一方、YouTube を見られるように、手続きを行う関数・クラスをひとまとめにしたプログラムを書いた場合、それはライブラリです。
この場合、ライブラリがアクセスするソフトウェアは固定ですが、ライブラリを使うソフトウェアは特定のモノが対象となっていないことに注意してください。


コンポーネントはソフトウェアの部品で、モジュールもソフトウェアの部品です。

モジュールはある手続き (関数やメソッド) とデータ構造をひとまとめにした部品です。
大抵の場合、モジュール単体でコンパイル可能ですが、動作はしません。
この説明だけだと、クラスとモジュールの違いがわからなくなりますが、一番大きな違いは、クラスはインスタンスとしてオブジェクトを生成しますが、モジュールは生成しない点でしょう。

コンポーネントはある機能を持ったプログラムの部品です。
大抵の場合、コンポーネント単体では動作しません。
非常に漠然とした回答で申し訳ないですが、モジュールを複数組み合わせた位のモノがコンポーネントと思っていただければありがたいです。
粒度的には
プログラム (←これ単体でやっと動く) > コンポーネント > モジュール > クラス
です。


さて、ココまでの回答ですが、全てちゃぶ台をひっくり返してしまいます。

業務のドメインや会社・組織、部署、チーム、はてはプロジェクトごとに、
コンポーネント、モジュール、その他もろもろの定義はぜんぜん違います。

はっきり言ってしまえば、どんなにえらい先生、専門家、スーパーエンジニアでも、これらの定義はまちまちです。

例えば、IT用語辞典 e-word において「コンポーネント」は「基本的に単体では使用できず」と書いてありますが、世界で始めて「コンポーネント」という概念を実装したのは Unix のパイプとフィルタであり、
当たり前ですが、ここで用いられている Unix の各種プログラムは単体で使用可能です。


ですので、実際のところは、あなたがこれくらいかなと思ったものがコンポーネントであり、モジュールです。


実のところ、勉強すればするほどわからなくなっていくお話ですが、漫然と過ごしてしまうと、このようなハードな疑問を抱けなくなってしまうかと思います。
どうか、これからも疑問を抱き続けてください。


最後に、まったくどうでもいい知識ですが、
世の中には Component Plugin Module というモジュールが存在しています。
    • good
    • 4
この回答へのお礼

S_Katsuyamaさん

素晴らしい回答ありがとうございます!
この様な回答をお待ちしていました。

> 実のところ、勉強すればするほどわからなくなっていくお話ですが、

そうなんです。
プログラムを書けば書くほど疑問が大きくなり、何が何なのかわからなくなってしまったので質問させて頂きました。

この様な回答を書ける方であれば、きっと素晴らしいプログラマかと思います。
一緒に仕事をしている人がうらやましいぐらいです。

> 世の中には Component Plugin Module というモジュールが存在しています。

そんな物があるんですね。知りませんでした。

いずれにしても本当にありがとうございました。

お礼日時:2010/07/20 08:08

ここに質問する前にネットで検索してね!



プラグインとは
コンポーネントとは
モジュールとは
ライブラリとは

のキーワードで検索すれば説明サイトが見れます。それでわからない部分を聞いてください。、そうずれば

>いずれも、あるプログラムをまとめたプログラムであると思っているのですが

と言うアホナ質問にならないと思いますよ。コンピューター関係の用語は、学校で国語とか漢文とか英語とか習うのと一緒で、まず辞書で調べましょう。

例: 授業で

This is a pen.

と黒板にかかれたら、penとは何ですか? と質問する人はいますかね?


ちなみに、それぞれ全く違う意味です。それぞれ元の意味があり、コンピューターの用語としては、このような意味になります。と言う説明になります。

例えば「ライブラリ」ですが「図書館」ですね。コンピューター用語としては、メインのプログラムから呼び出されるソフトの集合場所や、ソフトそのものを指します。

しかし、違う意味でも使われます。写真や動画の集めたフォルダーやアルバムを指します。これは、絵画や歴史的な資料をそろえている会館やオフィスなども指しますね。前後の文脈が重要ということですね。

>何をどういう基準で分ければいいのかと

と言う事でこの質問は的を得て質問されていないので、「それぞれ意味が違います」と言う回答が正しかと思いますよ。
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!


おすすめ情報