PHP と JavaScript は、型のジャグリングとキャストの際に 8 進数と 16 進数を扱うのが難しいことに気付きました。
PHP:
echo 16 == '0x10' ? 'true' : 'false'; //true, as expected
echo 8 == '010' ? 'true' : 'false'; //false, o_O
echo (int)'0x10'; //0, o_O
echo intval('0x10'); //0, o_O
echo (int)'010'; //10, o_O
echo intval('010'); //10, o_O
JavaScript:
console.log(16 == '0x10' ? 'true' : 'false'); //true, as expected
console.log(8 == '010' ? 'true' : 'false'); //false, o_O
console.log(parseInt('0x10')); //16, as expected
console.log(parseInt('010')); //8, as expected
console.log(Number('0x10')); //16, as expected
console.log(Number('010')); //10, o_O
PHP には8 進数/16 進数の誤動作を修正するoctdec()
と関数があることは知っていますが、JavaScript と同じように が 8 進数と 16 進数を処理することを期待しています。hexdec()
intval()
parseInt()
とにかく、この奇妙な行動の背後にある理論的根拠は何ですか?