如何(安全地)除最大值,得到浮点值?

How can I (safely) divide a maximum value, resulting in a floating point value?

本文关键字:最大值 安全 如何      更新时间:2023-10-16

我要计算转换因子。为此,我必须将例如ushort的最大值除以uchar的最大值。

我想动态地做到这一点,通过将参数传递给函数或类型名。然后我要选择最大值并执行计算。

有两个问题:

  1. 如何动态选择最大值?
  2. 我如何安全地划分这两个值?

已知所有值都适合double型的范围。

理想情况下,我想这样做:

double x = numeric_limits<T>::max / numeric_limits<T2>::max;

你的建议应该行得通:

#include <iostream>
#include <limits>
template <typename T, typename T2>
double get_ratio()
{
    return static_cast<double>(std::numeric_limits<T>::max()) / std::numeric_limits<T2>::max();
}
int main()
{
    auto ratio = get_ratio<unsigned short, unsigned char>();
    std::cout << ratio << 'n';
    return 0;
}
演示