Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
なぜPHPにはEnumがないのか
Search
Takayuki Fujisawa
October 30, 2019
Programming
5.2k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
なぜPHPにはEnumがないのか
Takayuki Fujisawa
October 30, 2019
More Decks by Takayuki Fujisawa
See All by Takayuki Fujisawa
RFC駆動のPHP学習術 Fukuoka.php edition
takayukifujisawa
1
450
RFC駆動のPHP学習術.pdf
takayukifujisawa
3
440
PHPのEnum事情
takayukifujisawa
1
770
レガシーなアプリケーションにこそTypeScriptを採用するべきではないかと思ったのでちょっとまとめてみたよっていう話をするスライドです / Legacy code needs TypeScript
takayukifujisawa
1
440
History of JavaScript
takayukifujisawa
1
230
usb_boot_ubuntu
takayukifujisawa
0
260
Other Decks in Programming
See All in Programming
AI時代のUIはどこへ行く?その2!
yusukebe
19
6.7k
TypeSpec で繋ぐ複数プロダクトの型安全
maroon8021
1
380
3Dシーンの圧縮
fadis
1
650
GitHub Copilot CLIのいいところ
htkym
2
1.3k
Claspは野良GASの夢をみるか
takter00
0
170
今さら聞けないCancellationToken
htkym
0
220
IBM Bobを活用したレガシーアプリの最新化
oniak3ibm
PRO
1
170
タクシーアプリ『GO』の バックエンド開発のおける AI利活用と若者のすべて
pyama86
3
1.9k
dRuby over BLE
makicamel
2
320
The NotImplementedError Problem in Ruby
koic
1
600
ビジネスモデルから紐解く、AI+型駆動開発
hirokiomote
2
5.2k
Observability in Practice:Grafana 與 Edge Device SRE 的那些事
blueswen
0
120
Featured
See All Featured
How Software Deployment tools have changed in the past 20 years
geshan
0
34k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
49
10k
From π to Pie charts
rasagy
0
200
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
530
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
270
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
580
Pawsitive SEO: Lessons from My Dog (and Many Mistakes) on Thriving as a Consultant in the Age of AI
davidcarrasco
0
160
Prompt Engineering for Job Search
mfonobong
0
330
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
200
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
150
Building AI with AI
inesmontani
PRO
1
1.1k
Navigating Weather and Climate Data
rabernat
0
210
Transcript
なぜPHP にはEnum がないのか @miracle_fjsw 1
whoami $iam = [ " 名前" => "Takayuki Fujisawa", "
会社" => " 株式会社ラクス", " 仕事" => ["R&D", " 技術広報, " エンジニアリングカルチャー促進", "PMO"], " トゥイッター" => "@miracle_fjsw" ] 2
「PHP にはEnum がない」と嘆く⼈が⼀定数いる 3
⼤体「厳密な型付けのためのEnum がない」という⽂脈で⾔われ ているケースが多いようです 以下、「厳密な型付けのためのEnum 」という⽂脈で語ります。 4
Enum って何よ 列挙型(enumration type) いーなむ、いにゅーむ、えなむ… 列挙型とは、データベースやプログラミング⾔語などにおけるデータ型の⼀つで、 複数の異なる定数を⼀つの集合として定義するもの。多くの⾔語では “enum” の略号で⽰される。 こういうやつ
enum Planet { MERCURY, VENUS, EARTH, MARS, ... } 5
Enum があると何が嬉しいのか 定数をただの数値や⽂字列ではなく意味を持った集合として定義できる 6
Enum がない場合こうなる function distance(int from_planet_id, int dist_planet_id) { // 処理
} 7
Enum がない場合こうなる const PLANET_ID_MERCURY = 1; const PLANET_ID_VENUS = 2;
const PLANET_ID_EARTH = 3; const PLANET_ID_MARS = 4; //// $distance = distance(PLANET_ID_MERCURY, PLANET_ID_VENUS); 8
Enum がない場合こうなる $distance = distance(PLANET_ID_MERCURY, PLANET_ID_VENUS); PLANET_ID_xxx はあくまで、ラベルをつけただけで内部的にはただの整数値 distance(1, 2);
これでも呼び出せる distance(1, 100000); これでも呼び出せる distance(OTHER_CONSTANT_A, OTHER_CONSTANT_B); これでも呼び出せる メソッドを使う⼈がちゃんと使ってくれることを祈るしかない PHPDoc やドキュメントなどで使い⽅の説明をしなければならない 内部での⼊⼒値チェックを⾏わなければならない 9
Enum があればこうできる enum Planet { MERCURY, VENUS, EARTH, MARS, ...
} function distance(Planet from, Planet dist) { // 処理 } $distance = distance(Planet::MERCURY, Planet::VENUS); メソッドの仕様がコードをみるだけで⼀⽬瞭然 型が縛られるため、Planet で定義した要素以外渡ってこない(安全) コードはいかにその仕様や概念を読み⼿に伝えるかが重要 定数によって管理されているそれはどこまで⾏っても数値や⽂字列でしかない Enum を使うことで意味‧概念をそのまま表現できる 他にも、返却値をboolean や定数ではなく、Enum で表現したり⾊々便利 10
なぜPHP にはEnum がないのか 11
実はPHP にもEnum はあります 12
PHP にもEnum はあります SplEnum Standart PHP Libraly を冠している割に本体に未だ統合されず、「実験的」のまま 13
PHP にもEnum はあります サードパーティ製 myclabs/php-enum 『SplEnum が本体に統合されてないから作りました』 BenSampo/laravel-enum 「php enum
」で検索すると⼤量の「作ってみました」系記事 14
Enum が欲しいという要望は多いものの、標準仕様には未採⽤ 15
RFC を⾒てみよう 2015 年に提案があるものの、未だドラフト。 16
RFC を⾒てみよう もっと古いのもあるが、議論中で⽌まっている 17
どうなってるの? 18
この謎を解くべく、過去のディスカッションの中⾝を追う PHP コミュニティのメーリングリスト https://externals.io/ Enum 関連で盛り上がっているスレッドが2 本(2012 年,2015 年) 2012
年の議論は凄まじい激論 2012 年というとPHP5.4 くらい すでにタイプヒンティング(引数の型指定 ※)などは導⼊されておりPHP が 型付けを意識しはじめている段階 ※ … クラス/ インタフェース、配列のみ。int やstring などのスカラ型は⾮対 応。 19
2012 年の議論を超意訳して抜粋 Enum 要らない派の猛攻 PHP は緩い型付けの⾔語なんや。便利なシーンも多いやろ。 厳密な型付けは実⾏時の速度を落とすからアカン。 そもそもコンパイル⾔語じゃないから厳密に型をしばったところで、事前に ⾒つけられへん。ボンクラが間違った実装しとったら実⾏時に落ちるやろ。 厳密な型付けが欲しい?Java
使えば? 厳密さが欲しい⼈ばっかりやないねん。⾃分が正しいみたいに⾔うなや。 という泥沼感のある議論が、なんだかよくわからないうちにストップ 20
実際、Enum は必要なのか? 便利で強⼒はあるが「必ず要る」わけではない。 クラスを使って同じことが実現できる。 class Planet { ... } class
Mercury extends Planet { ... } class Venus extends Planet { ... } class Earth extends Planet { ... } function distance(Planet from, Planet dist) { // 処理 } $distance = distance(Mercury::getInstance(), Venus::getInstance()); 当時のPHP コミュニティの⼈たちの意⾒も理解できる。 21
ところが、2015 年の議論では⾵向きが変わる 突如「Enum について議論しようず!」というスレが⽴つ 2015 年というとPHP7 のリリース。 厳密な型判定(strict )モードの追加 スカラ型宣⾔の機能追加(引数の型にint
やstring などを指定できる) 現在ドラフト中のRFC が作られたのもこの時期 22
2015 年の議論 2012 年とは違い、PHP に組み込むとしたらどのような仕様が良いのかが前向きに 議論されている Enum に振る舞いをもたせる必要あるか(※)、とか、シリアライズする時どうす るの、とか ※C++
などのEnum は定数の集合だが、Java のEnum はクラスの亜種であり、メ ソッドを持てる PHP に組み込む上での実装上の問題についての議論なども 過去に⾒られた「Enum 要らない派」がほとんどいない 23
つまり… PHP はもともと緩い型付けで柔軟に記述できる⾔語 これは別の視点ではあまり深く考えずにサクッと作れる強⼒な⾔語、とも⾔ える PHP の⽣みの親であるラスマス‧ラードフの⾔からも窺い知れる 『PHP は問題を解決するシンプルなツール以上のものではない』 実際そうだし、だからこそ広く愛⽤されるに⾄った⾔語。
24
つまり… かつてはEnum のような厳密に型を意識したいというアプローチは受け⼊れられに くかった そもそも必要としている⼈ばかりではなかった(代替⼿段もあるし) ⼀⽅で、ここ数年では徐々にコミュニティの考え⽅が変わってきており、PHP ⾃ 体が型を意識した⾔語に変容している 現在はその過渡期であり、完全にEnum 採⽤が棄却されたわけではない
25
という資料をまとめていた折 Union Types が投票フェーズに(現状賛成⼤多数) こういうやつ public function setNumber(int|float $number): void
{ $this->number = $number; } public function getNumber(): int|float { return $this->number; } 26
UnionTypes は2015 年に⼀度ポシャっている てことは、Enum もワンチャンあるで! 27
xdebug の開発者であり、RFC の投票者でもあるDerick Rethans のツイート 「Enum の議論⽌まってるみたいやけど、なんか詳しいこと知ってます?」という 問に対し 「あんま知らんけど、UnionTypes がマージされたらもっかい⾒なアカンね」
28
PHP にEnum が来る⽇はそんなに遠くない… ? 29
なぜPHP にはEnum がないのか @miracle_fjsw 30
なぜ今はPHP にはEnum がないのか @miracle_fjsw 31
以上。 32