deg2rad函数将角度值(单位:度)精确转换为弧度,仅接受纯数字或可转为数字的值,传入非法字符串如"45 deg"会静默转为0;其内置类型处理、性能优势及语义清晰性优于手动计算。

deg2rad 函数直接转,但别传错单位
deg2rad 就是干这事的:把角度值转成弧度。它只接受一个参数——纯数字,单位是「度」,不是「度分秒」,也不是带单位字符串。传 "45°" 或 45.0 都行,但传 "45 deg" 会返回 0(PHP 会静默转成 int 0)。
- 正确用法:
deg2rad(90)→1.5707963267949 - 错误写法:
deg2rad("90°")→ 实际算的是deg2rad(0) - 注意浮点精度:
deg2rad(180)不严格等于M_PI,但误差在1e-15级别,三角函数计算中可忽略
为什么不用自己写 $angle * M_PI / 180
手动算看起来更透明,但容易漏掉边界处理和类型转换。比如传入 null、空字符串或数组时,deg2rad 会返回 0.0(且不报错),而手写表达式可能触发 notice 或 warning。
-
deg2rad(null)→0.0;null * M_PI / 180→0(但会报Notice: A non well formed numeric value encountered) - 整数性能略好:内置函数底层用 C 实现,比 PHP 表达式快约 15%~20%,高频调用(如图形批量计算)值得用原生
- 语义清晰:看到
deg2rad就知道意图,比数学表达式更易维护
和 rad2deg 配对使用时要注意精度丢失
来回转一次不保等价。比如 rad2deg(deg2rad(42)) 可能返回 42.00000000000001,这不是 bug,是浮点二进制表示的固有局限。
- 比较时别用
===:改用abs($a - $b) - 显示给用户前记得
round($val, 6),否则可能看到一长串小数 - 如果业务要求严格可逆(如地理坐标序列化),建议全程用弧度存储,仅在输入/输出层做一次转换
在 trigonometric 函数里必须用弧度,但别假设所有函数都接受
PHP 的 sin、cos、tan 等三角函数只认弧度。传角度进去结果完全不对——比如 sin(90) 返回的是 0.89399666360056(90 弧度 ≈ 5156° 的正弦),不是你想要的 1。
立即学习“PHP免费学习笔记(深入)”;
- 常见误用:
sin(45)想求 45° 正弦 → 应写sin(deg2rad(45)) - 有些扩展(如
ext/gmp)不涉及角度,不用管;但数学、图像、GIS 相关代码几乎都绕不开这个转换 - 如果项目大量混用角度/弧度,建议封装一层:
function sin_deg($deg) { return sin(deg2rad($deg)); }
事情说清了就结束











