🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Java

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

Q&A

解決済

2回答

16914閲覧

BeanUtils.copyproperties()で利用しても良い/悪いの境界線とは

cha-ra

総合スコア40

Java

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

1グッド

3クリップ

投稿2016/11/28 08:47

最近apache.commonsのBeanUtils#copyProperties()が便利なのでよく利用しているのですが、
基本的にコピー元とコピー先に同名で同じ型の変数があることを期待しているわけですよね。

「DBEntity <=> DTO」みたいな場合は利用する際にはそれ程気にならないのですが、
「各Class <=> 共通DTO」みたいな場合でも利用して良いのでしょうか?
それとも、Interfaceを作成して各Classに実装したうえで、
DTOに対して値をコピーする方が良い実装なのでしょうか?

コピー元・先の実装に依存するので、どこまで利用範囲を広げて良いのかとても悩みます。
変数名に対する命名規則が厳格に定まっている場合にのみ、
「各Class <=> 共通DTO」を利用しても良いのかなとも思っています。

A-pZ👍を押しています

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

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

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

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

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

guest

回答2

0

ベストアンサー

"変数名に対する命名規則が厳格に定まっている場合" よりも、共通DTOと実際に扱うDTOとのフィールド差分をどこまで許容するかのインタフェース設計が大事になるでしょう。

BeanUtilsの良いところでもあり、あまり良いところではないとも思えるところですが、転写元のインスタンスがもつフィールドを、転写先は全てもつ必要がないので(ランタイム例外にならない)、おっしゃる通り、厳密なルールでDTOを設計したいのであれば、インタフェースを用意して必須のフィールドに対するset/getメソッドなりを定義するのも1つの手です。

投稿2016/11/29 04:50

A-pZ

総合スコア12011

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

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

cha-ra

2016/11/30 01:40

必ずしも一致するとは限らない変数名よりも、 基本的にはインターフェースでのやり取りの方が安心/安全ですね。 同じ型同士だったら問題なくコピー出来るとは思いますが、 clone()を利用する手もあるので、そうなってくるとBeanUtilsの使いどころってどこなんなんだろう?って益々悩んでしまいます。
A-pZ

2016/11/30 05:13

まさしくそこが肝となるところでして、完全転写するならBeanUtils使うことはないのですが、片方にだけ存在するフィールドを無視して転写できるのが強みです。 セッション情報を一部コピーしてDTOに詰める場合や、入力データと出力データとで似たようなDTOを扱う場合に、部分的に表示したくないフィールドがあった場合などに、1つ1つ転写するのではなく、一括でコピー→存在しないフィールドなら無視する、といった使い方もできます。
guest

0

<=>
この意味がわからないので答えられません。。

投稿2016/11/29 01:46

tantanegg

総合スコア213

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

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

退会済みユーザー

退会済みユーザー

2016/11/29 04:57

基本的に相互変換(文字化け回避)
tantanegg

2016/11/29 05:08

ご教授ありがとうございます。 個人的にはcopyProperties()は裏技だと思っています。 (DBEntity <=> DTO)は便利なので使ったほうがいいと思いますし使いますが、 それありきで考えるのは私はあまりしたくありません。
退会済みユーザー

退会済みユーザー

2016/11/29 05:25 編集

まあ私もコンバータ自作を使うね。 拡張時に余計なコピー抑止のため フレームワークが使っているのはしょうがないが
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問