質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.35%

  • C#

    9666questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • デザインパターン

    83questions

    デザインパターンは、ソフトウェアのデザインでよく起きる問題に対して、解決策をノウハウとして蓄積し再利用出来るようにした設計パターンを指します。

Iteratorパターン(デザインパターン)と.NetのGenericの違い

解決済

回答 5

投稿

  • 評価
  • クリップ 0
  • VIEW 1,820

yougo0411

score 10

オブジェクト指向の勉強の一環としてGofのデザインパターンを
C#でサンプルプログラミング中です。

その中で、Iteratorパターン(並び替え)がありますが、
Iteratorパターンと.NetにあるListやGeneric機能の違いが分かりません。

ListにもGeericにもSortメソッドや、Indexからピンポイントでの値取得も可能です。

何か考え違いしていますでしょうか。
また、もっとIteratorパターンにはもっと大きなメリットがあるのでしょうか。

宜しくお願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 5

+2

デザインパターンは、アルゴリズムではありません。
なので、Iteratorパターンも並べ替えではありません。
一言で言うと「複数のオブジェクトを順番に辿り処理していく」という内容のものです。
どのような順番で辿るのかは、Iteratorの実装によります。
データ構造を変更する訳ではありませんので、並べ替え処理ではありません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

checkベストアンサー

+1

こんにちは。

Iteratorパターンと.NetにあるListやGeneric機能の違いが分かりません。

Iteratorパターンは、「要素を枚挙するためのインターフェース」を定義し、このインターフェースを継承したコンテナの要素を枚挙する場合は常に同じ使い方(インターフェース)でできるようにするという考え方です。
Genericsは、異なる型でも同じアルゴリズムで取り扱えるケースについて「型」をバラメータとして与えることで、異なる型に対して同じアルゴリズムを適用させるための仕組みです。

つまり、Iteratorパターンはインターフェースを共通化することで使い方を統一するという考え方で、Genericsは実装をなんども書かなくて良くする仕組みです。

さて、List<T>には両方が使われてますね。
IEnumerable<T>が「要素を枚挙するためのインターフェース」のC#における実装です。これを継承しているので、Listを使う人はIEnumerable<T>インターフェースに従ってList内の要素を枚挙できます。
また、List<T>はT型のデータを保持できます。追加/削除等のアルゴリズムは型Tが異なっても同じアルゴリズムで対応できるのでGenericsで実装されてます。

IEnumerable<T>インターフェースを継承しているGenericsクラスで良く使われるものにDictionary<TKey, TValue>もありますね。List<T>とDictionary<TKey, TValue>ではデータの使い方が異なるので同じアルゴリズムで実装できないため、異なるGenericsクラスで実装されてます。
しかし、使う人はListを使う時と同じ方法で要素を枚挙できます。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

こんにちは。

間違ってませんよ。
List<T>はIEnumerableを実装しています。
C#でイテレータを実装する場合は上記インターフェイスを使用します。
なのでList<T>はIteratorなクラスです。

ただし、GenericはList<T>でいうTの部分です。
GenericではないIterator実装も当然ありますので混同しないほうが良いでしょう。


<追記>
誤りがありました。
StripeさんがおっしゃっているようにIteratorパターンはインターフェイスを提供する意味で使うもので、中身の実装(順番とか並び替えとか)に焦点をあてたものではありません。
そうした中で「間違ってませんよ」と回答してしまったのは不適切だったかも。訂正します。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

遅くなりましたが以下のように理解しました。
・「複数のオブジェクトを順番に辿り処理していく」を何度も実装しないためにIteraterパターンを用いる。
・定義したインターフェースを型パラメータとする事で、そのインターフェイスを継承した様々な型をIteraterの対象とする。
・更にオブジェクトの集合体から「順番に辿り処理していく」を分離させると、巡り順が汎用的であり対象も様々の型とする、事ができる。

こんな感じでどうでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

-1

デザインパターンは、何らかの処理やデータ構造などを設計するときの「典型例」に名前を付けたものなので、実際にC#などのクラスライブラリに実装されているクラスとの機能の違いを比較することは、あまり意味がありません。

なかなか説明するのは難しいのですが、デザインパターンは、GoFたちが「こういう処理をするにはこういう設計にすればなんとなく良さそうな感じだよね」というものをサンプルコード付きでまとめたものです。一方のC#のクラスライブラリは、マイクロソフトが「こういう処理をするにはこのクラスが必要だ」と考えて作ったものです。
つまり、両者は目的も考え方も違います。同じように見えるのは、最初に書いたようにIteratorパターンが「典型例」だからです。

もっとIteratorパターンにはもっと大きなメリットがあるのでしょうか。 

ないです。あまり深く考えてはいけません。自分がC#で何か作ろうとして、それがListやGenericでできることであればそれを使えば良いです。もしListやGenericできないことなら、Iteratorパターンは、おそらく参考にはなりません。

とはいえ、ある処理をどう設計/実装するかの勉強には良い教材だと思います。Listクラスは中身を見ることができないので、Iteratorパターンの方は「設計の勉強になる」という点がメリットかもしれません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • C#

    9666questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • デザインパターン

    83questions

    デザインパターンは、ソフトウェアのデザインでよく起きる問題に対して、解決策をノウハウとして蓄積し再利用出来るようにした設計パターンを指します。