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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Java

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

Q&A

解決済

3回答

3070閲覧

Javaで、クラスをまとめたListをどこに書くべきか

退会済みユーザー

退会済みユーザー

総合スコア0

Java

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

1グッド

0クリップ

投稿2018/10/18 08:18

前提・実現したいこと

こんにちは。独学でJavaを勉強中のものです。
考え方で分からないことがあったので質問させていただきます。

具体例として、下記のようなクラスBookがあり、そのBookクラスをまとめたBookshelf(本棚)というものを作りたいと考えています。
このBookshelfは文字通り本棚のような役割を果たし、いろいろな人(他クラス)から取り出したり追加したりできるものです。
このBookshelfをどこに書けばいいのか、という点で悩んでいます。

lang

1public class Book { //本を表すクラス。コンストラクタなどは省略 2 private String name; 3 private int value; 4 ... 5}

自分は今、このBookクラス内にstaticフィールドとしてbookshelfを作っているのですが、もっといい方法がありそうな気がします。

lang

1public class Book { //getter、setterは省略 2 private static List<Book> bookshelf = new ArrayList<>(); 3 4 private String name; 5 private int value; 6 ... 7}

試したこと - Bookshelfクラスを作る

lang

1public class Bookshelf { //コンストラクタなどは省略 2 private List<Book> bookshelf = new ArrayList<>(); 3 4 public void add(Book book) { 5 //本の追加 6 } 7}

色んな書籍だと、この方法が多いような気がしました。
しかし、自分が使っていない理由として、
1、本棚を使いたいクラスがあるたびにインスタンスを作る必要があるのでメモリの無駄
2、このクラスはBookクラスしか扱わないので、Bookクラス内に本棚を作ったほうがいいと思った

補足情報

状況によって最適なことは変わると思いますが、この場合はこう、のような具体例やその理由があると助かります。

LouiS0616👍を押しています

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

基本的にはBookshelfクラスを作ることをお勧めします。
フィールドにオブジェクトを持つのはhas-aの関係と言われており、今回でいえばBookshelf has a Bookとなり設計としてとても自然です。

本棚を使いたいクラスがあるたびにインスタンスを作る必要があるのでメモリの無駄

singletonやflyweightパターンで解決できそうです。

このクラスはBookクラスしか扱わないので、Bookクラス内に本棚を作ったほうがいいと思った

本と本棚は異なるものなので別クラスでも違和感はないです。

また、Bookshelfを別クラスにする場合、Bookshelfとして独自のメソッドを定義することができます。(FirstClassCollectionパターン)
Bookクラス内にstaticなListとしてBookshelfを持つ場合、BookshelfはListのメソッドしか使えませんし、独自のメソッドを足そうとするとBookクラス内にBookshelf用のstaticなメソッドが増えていくことになります。

投稿2018/10/18 08:46

YamakawaJunichi

総合スコア630

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/10/18 09:33

回答ありがとうございます。 「Bookshelf用のstaticなメソッドが増えていく」というのがまさに悩ましかったところでした。 この方針でソースコードを書き換えられるか考えてみます。
guest

0

Bookshelf クラスを作成することをおすすめします。

1、本棚を使いたいクラスがあるたびにインスタンスを作る必要があるのでメモリの無駄

Javaでは基本的にメモリの効率的な管理を開発者が試行錯誤しなくていいはずです。

2、このクラスはBookクラスしか扱わないので、Bookクラス内に本棚を作ったほうがいいと思った

Book クラスが使うんですか?個人的には逆に感じます。
Bookshelf に対して本の出し入れを管理するのではないでしょうか。

java

1bookshelf.findByTitle("Effective Java") // => List<Book> 2 3bookshelf.saveNewBook(book)

投稿2018/10/18 08:42

mather

総合スコア6753

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mather

2018/10/18 08:44

なお、「シングルトンパターン」などのデザインパターンの例も参考にしてくださいね。 全部デザインパターンを参考にしろとは言いませんが、いくつかの例を読んでおくのはためになると思います。
退会済みユーザー

退会済みユーザー

2018/10/18 09:35

回答ありがとうございます。 今まさにデザインパターンを勉強していた所なので、ちゃんと使えるように頑張ります。
guest

0

設計次第なのでどちらも間違いではありません。

現実世界で考えると、本棚には本が入る上限がありますよね?
本が本棚に入り切らなくなったら新しい本棚を用意する必要があるので、
そういう実装ではBookShelfクラスを作って、必要になるたびに生成することになります。

では、本が無限に入る本棚があるとして、全ての本はその本棚にしまわれるとします。
そういうときにはBookクラスにstaticなBookShelfを用意しても問題ありません。

ただ、たとえばお兄さんの部屋に本があり、弟くんの部屋にも本がある場合、
staticなBookShelfは果たして正しい設計と言えるでしょうか?
それぞれの部屋に別々の本棚があるべきですよね。

この家は書庫にでかい本棚があって、お兄さんと弟くんはそこに本をおいている
ということであればstaticなBookShelfを持つという設計で合っています。

一般的には本棚は複数あるものという認識なので、BookShelfクラスを作る方が
例として用意されてるのが多いのではないでしょうか。

設計によりけり、ということです。

投稿2018/10/18 08:36

dice142

総合スコア5158

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/10/18 09:37

自分の中で、本棚は一つしかない、という思い込みがあったみたいです。 抽象的な内容にもかかわらず具体的な説明が分かりやすかったです。 回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問