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
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
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
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
150
AIとASP.NET Coreで雑Webアプリを作った話
mayuki
0
320
The Arts and Crafts of Work in the AI Era — Toward Mastery in Software Development
kuranuki
1
720
決定論的オーケストレーションの設計と実装 / Design and Implementation of Deterministic Orchestration
nrslib
3
1.1k
関係性から理解する"同一性"の型用語たち
pvcresin
2
640
AI時代の仕事技芸論 — ソフトウェア開発で「遊ぶように働く」職人的熟達のすすめ
kuranuki
1
610
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
250
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
220
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
500
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
1.1k
Modding RubyKaigi for Myself
yui_knk
0
890
権限チェックの一貫性を型で守る TypeScript による多層防御
mnch
4
1.1k
Featured
See All Featured
jQuery: Nuts, Bolts and Bling
dougneiner
66
8.5k
How to make the Groovebox
asonas
2
2.2k
What does AI have to do with Human Rights?
axbom
PRO
1
2.2k
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
270
Making Projects Easy
brettharned
120
6.7k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
220
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
2
210
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
380
Testing 201, or: Great Expectations
jmmastey
46
8.2k
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
Raft: Consensus for Rubyists
vanstee
141
7.5k
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