複数の引数をまとめて読みやすくするパラメータ•オブジェクト|Parameter Object
記事更新日:2024-02-04
data:image/s3,"s3://crabby-images/31e36/31e369c9bcb7b93bb47f37ebc9ae3492a4c291ad" alt="サムネイル"
まとめよう
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
まとめる手段がオブジェクト
同じパラメータの組み合わせが出現する場合は、オブジェクトにすることを検討してください
IMPREMENTATION PATTERNS
If a group of parameters is passed together to many methods, consider making an object
data:image/s3,"s3://crabby-images/cda91/cda9146fb3ac6e00f65d8e4e0ad7404b264c9db0" alt=""
ちなみに、パラメータ(parameter)は厳密に言うと「仮引数」
- parameter(仮引数)
- 関数側での定義
- x, y など名前で表現されたもの
- 値を仮定したものだから仮引数
- argument(実引数)
- 呼び出し側が渡すもの
- 実際に渡す値そのものだから実引数
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
関数側から見れば parameter objectで、呼び出し側から見れば argument object
パラメータ・オブジェクトとは|Parameter Object
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
引数をオブジェクトにする手法
必要な情報をまとめて渡す手段
関連するパラメータを1つのオブジェクトにまとめるデザインパターン
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
デザインパターンとして定着している
パラメータ・オブジェクトの利点
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
シンプルだし、ミスが減るし、ロジック見直しのきっかけにもなる
- 短くて読みやすい
- 正確な情報がまとまっているから、情報不足などのミスを減らせる
- 新たなロジックに気づける
- 同じ組み合わせ → 関連データとしてのロジック見直し
- 情報数を可変にできる
唯一の懸念点はパフォーマンスの問題だが、ほとんどの場合、問題にならないレベル
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
利点だけ考えて問題ない
パラメータ・オブジェクトを使うべきとき
同じ組み合わせが何度か登場するとき
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
たとえば、こんなとき
- 「縦、横、高さ、幅」など、サイズの組み合わせが同じ
- 状態などの情報の組み合わせが同じ
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
同じ組み合わせなら、オブジェクト候補
単純に、引数を減らしたいとき
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
同じ組み合わせじゃなく、引数を減らす目的でもOK
引数からオブジェクトを作成して引数の数を減らすのは、不正行為のように見えるかもしれませんが、そうではありません。
Clean code
Reducing the number of arguments by creating objects out of them may seem like cheating, but it’s not.
data:image/s3,"s3://crabby-images/cda91/cda9146fb3ac6e00f65d8e4e0ad7404b264c9db0" alt=""
そもそも3つ以上の引数は多すぎると言われてる
3 つの引数 (triadic) は可能な限り避けるべきです。 3 つ以上(polyadic) は特別な理由がなければ使用すべきではありません
Clean code
Three arguments (triadic) should be avoided where possible. More than three (polyadic) requires very special justification—and then shouldn’t be used anyway.
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
引数の数を減らすのも、大事な目的
パラメータ・オブジェクトを作るときの検討事項
パラメータオブジェクトは、ロジックの重要な拠点になりうる
parameter objects can become important homes for logic.
どの形態を選ぶか
配列、コレクション、key-value型など
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
状況によって、ふさわしいものが異なる
中身はわかりやすいか
オブジェクトの中身が何であるかが理解しづらくなるのがデメリット
デメリットを最小限にするための工夫が必要
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
たとえば、こんな工夫
- オブジェクト名やkey名をわかりやすくする
- 格納するものが固定の場合(静的)
- 固定のkey名 / 空のitemで先に初期設定し、オブジェクトの中身を明示する
- あちこちで新規追加しない
- 格納するものが可変の場合(動的)
- できるだけ予測可能なkeyにする
- たとえばテーブルの値を格納するなら、フィールド名をkeyにする等
- できるだけ予測可能なkeyにする
メソッドに変換できるか
data:image/s3,"s3://crabby-images/a8f9c/a8f9c889ae9b718ba98651923a7691e69a3a31c0" alt=""
パラメータの組み合わせがメソッドになるかもしれない
長いパラメータリストをオブジェクトに置き換えたら、それらがメソッドに変換できるかを検討します
IMPREMENTATION PATTERNS
Once you have replaced the long parameter lists with the parameter object, see if there are bits of code using only the fields in the parameter object that you could turn into methods on the parameter object.
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
なぜメソッドになるの?
あるデータが複数の関数で使われるなら、互いに強く関連しているという手がかりになります
IMPREMENTATION PATTERNS
The fact that the data appears together in several parameter lists is a blatant clue that they are strongly related.
data:image/s3,"s3://crabby-images/cda91/cda9146fb3ac6e00f65d8e4e0ad7404b264c9db0" alt=""
つまり、オブジェクトがこう語りかけてくる
このデータの組み合わせは強く関連しています
This set of data is strong related.
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
単純なオブジェクトではなく、新たなロジックが発見できるかも
data:image/s3,"s3://crabby-images/cda91/cda9146fb3ac6e00f65d8e4e0ad7404b264c9db0" alt=""
ソロの歌手ではなく、グループ歌手であるという事実を発見しよう
複数の変数が一緒に渡される場合、1つに命名できる可能性があります
clean code
When groups of variables are passed together, they are likely part of a concept that deserves a name of its own.
data:image/s3,"s3://crabby-images/d1703/d17032924e577f08df80d64c65fb642d69a98230" alt=""
「ビートルズの楽曲」を、「ジョンとポールとジョージとリンゴの楽曲」と呼称するのは大変
明確に
1つの名前をつけること
data:image/s3,"s3://crabby-images/cda91/cda9146fb3ac6e00f65d8e4e0ad7404b264c9db0" alt=""
戻り値をまとめる場合は、コレクティング・パラメータ
2024-02-04
編集後記:
この記事の内容がベストではないかもしれません。