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

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

ただいまの
回答率

88.04%

UIViewControllerのインスタンスをどこに配置すべきか

解決済

回答 2

投稿 編集

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

score 76

Storyboardを使用せず、コードで画面遷移を管理しています。そのようなとき、UIViewControllerのインスタンスを確保して、どこかに配置しなければならないと思います。
使用するUIViewControllerの数が多い(20個以上)の場合、それらのインスタンスはどこに配置するのが適切と思われますか?

私が思う一つの方法は、UINavigationControllerのインスタンスを数個グローバルに配置し、それぞれのクラス内に複数のUIViewControllerのインスタンスをグルーピングする形で管理するのが良いかなと思いましたがどうでしょうか。

ご意見をお伺いしたいです。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

基本的な考えとして、なるべくグローバルに保持するのはやめた方がよいと思います。

たくさんViewControllerがあったとしても、各ViewControllerは、親のViewControllerから呼び出され、終わったらまた親ViewControllerに戻る親子関係があるはずです。
タブ画面のように複数のViewControllerが並行して存在する場合でも、その並行ViewControllerの共通の親となるUITabViewControllerがいます。
なので、基本的には呼び出し元の親ViewControllerが子供のViewControllerを管理すべきだと思います。
そうすることで、無駄にViewControllerを保持せず、必要な時に確保して不要になったらすぐ解放することができ、メモリ使用を最適化できます。プログラムが大きくなればなるほど、そのグローバル化の悪影響は大きくなります。

また、たくさんのViewControllerをグルーピングして管理したい場合、UINavigationControllerを使う必要はありません。グルーピングしたいUIViewControllerのインスタンスを配列(NSArray)で保持すればよいだけです。それを順番に表示したりナビゲーションバーを使って画面を行き来したいならUINavigationControllerを使えばよいですが、そうでないなら、単純にNSArrayに保持し、その中から必要なViewControllerを選択して表示すればよいだけです。そして、そのNSArrayはグローバルでなく表示元の親ViewControllerに保持すればよいです。


投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/09/18 16:11

    回答有り難うございます。
    仮にすべてのUIViewController間に親子関係が存在したとして、その根に最も親のUIViewControllerはグローバルで確保して良いのだろうか、と言うのが質問の趣旨でした。わかりづらくて申し訳ありません。
    また、親のUIViewControllerの一例としてUINavigationControllerを書いていました。初めから親のUIViewControllerと書くべきでした。こちらも誤解を招く表現をしてしまいすみませんでした。

    キャンセル

  • 2015/09/18 22:32 編集

    > 仮にすべてのUIViewController間に親子関係が存在したとして、その根に最も親のUIViewControllerはグローバルで確保して良いのだろうか、と言うのが質問の趣旨でした。

    一番の親となるViewControllerは、UIWindowのrootViewControllerに保持されます。もし、その一番の親となるViewControllerを複数個同時に保持して、UIWindowのrootViewControllerを適宜切り替えるようなことをしたいなら、その複数のViewControllerを保持した配列をグローバルに持つ必要があるかもしれませんが、たぶんそういうことをしたかったら、普通に1個の親ViewControllerをUIWindowのrootViewControllerに保持し、その親ViewControllerに複数のViewControllerを保持した配列を持たせた方がやりやすいと思います。
    もしその複数のViewControllerをユーザーが自由に切り替えるインターフェースを持たせたかったら、配列じゃなくてUITabBarControllerに保持すればいいです。あるいは順番に行き来するユーザーインターフェースを持たせたかったら配列じゃなくてUINavigationControllerに保持すればいいです。

    キャンセル

  • 2015/09/22 01:26

    なるほど。rootViewControllerに最も親のViewControllerをセットしておけば、階層的に切り替えられるのですね。
    また、UITabBarControllerやUINavigationControllerなどの整理も付きました。
    ありがとうございました。

    キャンセル

+1

それぞれのControllerが管理しているので、わざわざ自分で管理する必要はありません。(なにか特殊なことをしようとしているのなら話は別ですが)
例えば、NavigationControllerもTabBarControllerも、viewControllersというメンバに管理下のViewControllerを保存しています。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2015/09/18 16:13 編集

    回答ありがとうございます。
    UINavigationControllerとUITabBarControllerにそのようなメンバが存在するのですね。

    となると、class MyViewController 内で、self.navigationController?.viewControllers を参照すれば、グローバルでUIViewControllerを管理する必要なく、画面遷移が自由に行えるということでしょうか

    キャンセル

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

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

関連した質問

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