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

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

ただいまの
回答率

90.50%

  • Java

    13803questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • MVC

    224questions

    MVC(Model View Controller)は、オブジェクト指向プログラミングにおけるモデル・ビュー・コントローラーの総称であり、ソフトフェア開発で使われている構築パターンとしても呼ばれます。

  • MVVM

    76questions

    MVVM(Model View ViewModel)は構築上のデザインパターンで、表現ロジック(ViewModel)によってデータ(Model)からページ(View)を分離させます。

  • MVP

    2questions

クライアントアプリケーションにおけるインメモリモデルインスタンスの管理手法について教えてください

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 250

koban

score 6

Java + swt で 簡単なSQLエディターデスクトップアプリケーションを作成しています。
ライブラリとしてGuice,EventBusを利用しています。

編集対象を、以下のClassで表現しています。

public class Target {

    public TargetKey key;

    public HeaderProperties headerProperties;

    public EditOptionProperties editOptionProperties;

    public SqlFileProperties sqlFileProperties;

    public String memo1;

    public String memo2;


}


Target クラスはメモリ内に保持し、また複数保持する事を考えています。
(例えばタブごとにそれぞれのTargetを編集できるように)

上記のようなモデルをView + Controlerで参照する際、モデルインスタンスはどのように管理するのでしょうか?

よくあるWebアプリケーションはメモリ内にモデルのインスタンスを保持する考え方ではなく
controlerにServiceクラスを用意して、その都度、モデルを生成しているようなイメージです。

例えばスコープ毎にGuiceのAbstractModuleを継承した自作クラスを作成していく考え方であってるのであれば、Contorolerに参照させるモデルの粒度でまた迷っています。

自分なりに2つの考え方があり、どっちに舵を切って開発していくか迷ってます。

■考え方1
view controlerはなるべく利用するモデルの範囲を限定した方が良い。

public class OptionAndMemoEditDialogControler {
    final EditOptionProperties editOptionProperties;

    final String memo1;

    final String memo2;

    @Inject
    public OptionAndMemoEditDialogControler(
            EditOptionProperties editOptionProperties, @Named("memo1") memo1, 
            @Named("memo2")String memo2) {

        this.editOptionProperties = editOptionProperties;
        this.memo1 = memo1;
        this.memo2 = memo2;
    }

■考え方2
どういったモデルの何のプロパティを扱うのかをわかるようにする

public class OptionAndMemoEditDialogControler {

    final EditOptionProperties editOptionProperties;

    final String memo1;

    final String memo2;

    @Inject
    public OptionAndMemoEditDialogControler(Target target) {
        super();

        this.editOptionProperties = target.editOptionProperties;
        this.memo1 = target.memo1;
        this.memo2 = target.memo2;
    }

}

考え方1では、controlerのコーディング・後からの変更はし易い分、どのモデルを注入するか
のコーディングが複雑になります。
考え方2では、controlerのコーディング・後からの変更が難しくなりそうな分、どのモデルを注入するかのコーディングはし易いです。

MVPやMVC等のアーキテクチャなど勉強しているのですが、controlerクラスにどのようにモデルを割り当てていくか良くわかりません。ご教授の程よろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

check解決した方法

0

controlerへのモデルの代入粒度に関してはいまだに悩ましく思ってますが、
モデルインスタンスの管理について、下記OSSプロジェクトが求めていた考え方だと理解しました。

scope tree based Dependency Injection

https://github.com/stephanenicolas/toothpick

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

  • 受付中

    sessionScopedなクラスの値の参照が出来ない

    JavaEEによるログイン機能の実現のために、session scopedなクラス(LoginSession)にログイン中のユーザーIDをsetする方法を考えています。 ログ

  • 解決済

    Javaの定数定義のグループ化について

    Javaの定数を定義する際に、グループ化のような記述を以前見た記憶があるのですが、記述方法を忘れてしまいました。 public class XxxConst { pub

  • 解決済

    ListViewでのCheckBoxにチェックが付かない

    前提・実現したいこと 現在ListViewで一覧を表示しているのですが、項目のLongClickからチェックボックスが表示され、複数選択出来るようなものを作りたいと思っています。

  • 解決済

    Springが提供しているサポートクラスについて

    いつもお世話になっております。 Springが提供しているサポートクラスについて質問があります。 下記のようなSpringが提供しているサポートクラスを作成しました packa

  • 解決済

    親サーブレットのロジックで子サーブレットのサーブレット名を取得

    【背景】 親サーブレットから遷移先に指定されているJSPで 呼び出し元(親サーブレットを継承し製造したサーブレット、以下子サーブレット)のサーブレット名を取得し、表示したいです

  • 解決済

    cakephp、エラー

    Cakephpでこちらのサイトを使って進めています http://tetra-themes.com/cakephp-howto-add-11/ 記事を追加するというところでエラーが

  • 解決済

    [Qt]Qtのイベント操作

    (趣味で)C++でやっています。 C++ではGUIはQtが楽らしいので使ってみました。 以前質問したDLL云々は何とか解決しました。 QtCreator付属のヘルプ (

  • 受付中

    他のクラスからJFrameのラベルのテキストを変更

    前提・実現したいこと JAVAプログラムをNetBeansで作っています。 JFrameにラベルを配置しました。 このラベルのテキストを他のクラスから変えるにはどうしたら良いでしょ

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

  • Java

    13803questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • MVC

    224questions

    MVC(Model View Controller)は、オブジェクト指向プログラミングにおけるモデル・ビュー・コントローラーの総称であり、ソフトフェア開発で使われている構築パターンとしても呼ばれます。

  • MVVM

    76questions

    MVVM(Model View ViewModel)は構築上のデザインパターンで、表現ロジック(ViewModel)によってデータ(Model)からページ(View)を分離させます。

  • MVP

    2questions

  • トップ
  • Javaに関する質問
  • クライアントアプリケーションにおけるインメモリモデルインスタンスの管理手法について教えてください