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

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

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

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

解決済

「Effective Java第3版 項目26 原型を使わない」についての質問(その2)

guijiu
guijiu

総合スコア20

Java

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

1回答

-1評価

0クリップ

234閲覧

投稿2022/01/14 02:08

編集2022/01/14 18:17

Effective Java第3版(以下、当該書籍という)でオブジェクト指向プログラミングを勉強いています。次の箇所について、意味がよく理解できないので、教えていただけないでしょうか。

1.理解できない不明部分(その1)

第5章 ジェネリックス
項目26 原型を使わない
120ページ 下から3行目に
「偶然に切手コレクションにコインを入れてしまう可能性はなさそうに見えるかもしれませんが、問題は現実にあります。」
という記述があります。この分は120ページ上段部分に次のコードが記述されており、これを受けてのことだと思います。

java

// 私の切手コレクション private final Collection stamps = ・・・ stamps.add(new Coin(・・・));

ここで質問ですが、なぜ切手コレクションにコインを入れてしまう可能性がなさそうと見えるのですか?著者の意図していることは、「変数名がstamps(切手の入れ物)にcoinを入れるような人は常識的に考えて、いるわけないだろ!」と言うことでしょうか?

2.理解できない不明部分(その2)

次に、「偶然に切手コレクションにコインを入れてしまう可能性はなさそうに見えるかもしれませんが、問題は現実にあります。」の文に続いて、「たとえば、BigDecimalインスタンスしか含んでいないと想定されるコレクションに、誰かがBigIntegerインスタンスを入れることは、想像に難しくないです。」
「問題は現実にあります」という部分がよく理解できないのですが、ここで言いたいことは、ジェネリックス型を使わないと、こういった凡ミスはよく起こりえるので、変数名をもとに人間の認知力・判断力に頼ってインスタンスを代入していると、想定していないクラスのインスタンスを誤って代入してしまい、実行時エラーを生じてしまうということでしょうか?(国語力の質問のようで申し訳ありません。)

理解を深めるために、この行(くだり)について簡単なコードを書いてみました。著者が言いたいことはこのようなコードでしょうか?

java

public class Item26_5 { public static void main(String[] args) { // プログラマの気持ちとしては、numbers変数にBigDecimal型のインスタンス入れたい。 final Collection numbers = new ArrayList(); numbers.add(new BigDecimal("10.3")); numbers.add(new BigDecimal("10.5")); numbers.add(new BigDecimal("1.4")); // 想定外のインスタンスの挿入 numbers.add(new BigInteger("12")); for (Iterator i = numbers.iterator(); i.hasNext(); ) { Object number = i.next(); // オブジェクト型のインスタンスのため、どんな型のインスタンスでも代入できてしまう。 System.out.println(number.toString()); } } }

結果、iteratorから振り出されるインスタンスはObject型で受け取るので、以下のように実行時エラーを出さずに、デシマルの他に、想定外としていた整数を含めて表示してしまった。

10.3 10.5 1.4 12

参考までに著者が望むジェネリックス型のコードは次の通りだと思いますが、いかがでしょうか?

java

public class Item26_6 { public static void main(String[] args) { final Collection<BigDecimal> numbers = new ArrayList<>(); // 実型パラメータ<BigDecimal>を加えパラメータ化された型にする numbers.add(new BigDecimal("10.3")); numbers.add(new BigDecimal("10.5")); numbers.add(new BigDecimal("1.4")); // 想定外のインスタンスの挿入 // numbers.add(new BigInteger("12")); // コンパイルエラーを生じるためコメントアウト for (Iterator<BigDecimal> i = numbers.iterator(); i.hasNext(); ) { // 実型パラメータ<BigDecimal>を加えパラメータ化された型にする BigDecimal number = i.next(); // numberの型をBigDecimalにし明確化する。 System.out.println(number.toString()); } } }

以上、半分国語力のような質問で恐縮ですが、ご教示のほどよろしくお願いします。

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

dodox86

2022/01/14 02:59

> 「偶然に切手コレクションにコインを入れてしまう可能性はなさそうに見えるかもしれませんが、問題は現実にあります。」 ... > ここで質問ですが、なぜ切手コレクションにコインを入れてしまう可能性がなさそうと見えるのですか? 原著、訳書を読んだわけではありませんが、問いかけているのは反対の意味では? 「切手のコレクションに間違ってコインをいれてしまうような事態は、現実世界でも起こり得ます。」と言っているのだと考えられます。
guijiu

2022/01/14 05:52

解説ありがとうございます。dodox86さんの解釈なら納得できます。当該書籍の「問題は現実にあります」の部分にひっかかっていました。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

Java

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