1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

システムハンガリアンでもいいじゃない(よくない)

Last updated at Posted at 2023-07-16

前書き

世間から嫌われているシステムハンガリアン記法を少しだけ擁護します。
またJavaScriptみたいなガチガチに型を意識させない言語を想定しています。

追記

コメント欄で教えていただきましたが、本記事で使っている記法はシステムハンガリアン記法ではなくイングリッシュ記法と言われるものだそうです。
という訳で、本文のシステムハンガリアン記法はイングリッシュ記法だと読み替えてください。

なお、システムハンガリアン記法は事前知識がないとなんだこれ?となりイングリッシュ記法よりも分かりにくいなと思いました。
イングリッシュ記法という上位互換がある以上、わざわざシステムハンガリアンを使うことはないでしょう。(手のひら返し)

本文

型は適切な変数名で分かるからいらん。
邪魔
見づらい
型が変わったときに変数名を直すのダルい。
システムハンガリアン許さん。このクソを擁護するやつも許さん。

と、思われているだろうシステムハンガリアンですが
私はすべてが駄目で一切使ってはいけない。とは思いません。

例えば次のようなコードはシステムハンガリアン記法を使うのがシンプルで分かりやすいと思います。
(少なくとも私は。)

const today = new Date();
const strToday = `${today.getFullYear()}${today.getMonth() + 1}${today.getDate()}日`;

today, strTodayは宣言後にテキトーに使われると考えといてください。
DBに登録されるとか、画面に表示されるとか、計算に使われるとかするんでしょう。きっと。

要するにシステムハンガリアン記法は、
型が違うけど名前が似てしまう!いい名前が思いつかん!って時に使うと、思考停止で命名できて、型の違いも分かって、普通にシンプルで、変数名も短くていいんでない。
ということです。
(ただtodayをdtTodayと書くのはさすがにないと思います。)

以上、終わり。

システムハンガリアン(笑)みたいな考えだと、仮にシステムハンガリアンが有用な場面が来ても見落としてしまうかもしれないので一応書いておきました。

1
1
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?