




std::hypot 比 sqrt(xx+yy) 更安全因内置防溢出缩放机制;C++17 起支持三参数 hypot(x,y,z),此前可用嵌套 hypot(hypot(x,y),z);性能略低但精度与鲁棒性显著更优。
因为 std::hypot 内部做了防溢出处理:当 x 或 y 很大(比如接近 DBL_MAX)时,x*x 会直接溢出为 inf,导致 sqrt(x*x + y*y) 返回错误结果;而 std::hypot(x, y) 会先缩放数值再计算,保证中间结果不溢出。
使用前需包含头文件:
#include
float、double、long double,重载版本自动匹配NaN,返回 NaN;任一为 inf,返回 inf
标准 C++17 起,std::hypot 增加了三参数重载:std::hypot(x, y, z),直接计算三维欧氏距离 √(x²+y²+z²),无需嵌套调用。
注意:C++14 及更早版本不支持三参数形式,强行使用会编译失败 —— 错误信息类似:
error: no matching function for call to 'hypot(double, double, double)'

-std=c++17
std::hypot(std::hypot(x, y), z),它也具备防溢出特性std::sqrt(x*x + y*y + z*z),同样有溢出风险std::hypot 比裸 sqrt 略慢(通常 2–5 倍),但换来的是数值鲁棒性。在绝大多数工程场景中,这点开销可接受;仅在高频循环且输入范围严格受限(如固定在 [-1, 1])时才考虑绕过。
std::hypot 在极端值下误差远小于 sqrt(x*x + y*y),尤其当两数数量级相差极大时(如 x = 1e-100, y = 1e100)sqrt 无实质问题;但一旦涉及物理*、坐标变换或用户输入,必须用 hypot
std::hypot(std::hypot(x,y),z) 和 C++17 三参数版在精度上等价,性能差异可忽略最常被跳过的其实是参数顺序和类型一致性。
std::hypot 不关心 x/y/z 的物理含义,只按传入顺序计算 —— 所以三维空间中,务必确认你的 x、y、z 是同一坐标系下的分量,别把高度当 x 传hypot(1, 2.5f, 3))会触发隐式转换,可能损失精度;建议显式统一为 double 或使用字面量后缀:hypot(1.0, 2.5f, 3.0)
std::hypot 重载解析,否则编译报错;必要时用 static_cast 显式转为浮点型std::hypot 就不该被跳过。