12

我正在做一个简单的程序来用开尔文、摄氏和华氏转换温度,但是在用开尔文做任何事情时我得到了这个错误:

Cannon implicitly convert type 'double' to 'float'

发生错误的行:

public static float FahrenheitToKelvin(float fahrenheit)
{
    return ((fahrenheit - 32) * 5) / 9 + 273.15;
}

按钮点击:

private void button1_Click(object sender, EventArgs e)
{
    var input = float.Parse(textBox1.Text);
    float FahrenResult = FahrenheitToCelsius(input);
    textBox2.Text = FahrenResult.ToString();
    float KelvinResult = FahrenheitToKelvin(input);
    textBox3.Text = KelvinResult.ToString();
}

我正在尝试制作的测试方法:

[TestMethod]
public void fahrenheitToKelvinBoiling()
{
    float fahrenheit = 212F;
    float expected = 373.15F; // TODO: Initialize to an appropriate value
    float actual;
    actual = Form1.FahrenheitToKelvin(fahrenheit);
    Assert.AreEqual(Math.Round(expected, 2), Math.Round(actual, 2));
    // Assert.Inconclusive("Verify the correctness of this test method.");
}
4

2 回答 2

13

尝试这个。

    public static float FahrenheitToKelvin(float fahrenheit)
    {
        return ((fahrenheit - 32f) * 5f) / 9f + 273.15f;
    }

这是有效的,因为它改变了编译器将 32 5 等识别为双精度数。数字后面的 f 告诉编译器它是一个浮点数。

于 2013-10-30T00:29:35.407 回答
0

编译器将生成的表达式提升为双精度。我认为它假设那些包含小数部分的数字是双倍的。

不过,您可以将结果值显式转换为浮点数;

或者您可以尝试将所有具有小数分隔符的常量显式转换为浮点数。

编辑

作为旁注,您是否完全习惯使用浮点数(或双精度数)而不是小数?我没有看到您的代码,最终当通过调用ToString () 方法向用户界面显示数据时,将值四舍五入到一定数量的精度数字(尽管您的单元测试会这样做)。

您可能会在浮动结束时获得一些“丢失”的精度数字,它们将通过使用 ToString() 显示到 UI。

我强烈建议:

  1. 使用四舍五入到一定的小数精度
  2. 将浮点数更改为小数
于 2013-10-30T00:32:34.840 回答