在循环中初始化双打给出错误 "variable might not have been initialized"

Initializing doubles in a loop giving error "variable might not have been initialized"

这个程序应该从用户那里得到一些邮件的重量并计算它的成本。 100g之后,成本增加$2.5/50g。但是,当我尝试 运行 程序时,它说“可变成本可能尚未初始化”。这是因为我在 if 语句或其他东西中对它进行了初始化吗?我知道有些人犯了错误,因为他们在 if 语句中声明了变量,但我在 if 语句之外声明了我的变量。我做错了什么。

import java.util.Scanner;
class Main {
  public static void main(String[] args) {
        Scanner in = new Scanner(System.in);

        double mailWeight;
        double cost;

    System.out.println("How much does your mail weigh (g)");
        mailWeight = in.nextDouble();

        in.close();

        if (mailWeight > 0 && mailWeight <= 30) {
            cost = 4;
        }else if (mailWeight > 30 && mailWeight <= 50) {
            cost = 5.50;
        }else if (mailWeight > 50) {
            double x = mailWeight - 100;
            if (x >= 50) {
                double y = x/50;
                Math.ceil(y);
                double z = y * 2.5;
                cost = z + 7;
            }
        }
        System.out.println(cost);
  }
}

如错误中所述,您尚未初始化“mailWeight”和“cost”这两个变量

由于它们是局部变量(在方法内),您需要在访问它们之前对其进行初始化。您通过赋予初始值进行初始化:

double mailWeight=0;
double cost=0;

如果最后一个 else if 语句出现并且 x < 50 或当 if 语句的 none 导致 mailWeight 为真时,它不会被初始化。您可以预初始化成本。 (双倍成本 = 0)或者您可以添加所有缺失的 else 块。在读取它之前,您需要在所有可能的情况下初始化您的变量。

这可能有效:

public static void main(String[] args) {
    Scanner in = new Scanner(System.in);

    double mailWeight;
    double cost;

    System.out.println("How much does your mail weigh (g)");
    mailWeight = in.nextDouble();

    in.close();

    if (mailWeight > 0 && mailWeight <= 30) {
        cost = 4;
    } else if (mailWeight > 30 && mailWeight <= 50) {
        cost = 5.50;
    } else if (mailWeight > 50) {
        double x = mailWeight - 100;
        if (x >= 50) {
            double y = x/50;
            Math.ceil(y);
            double z = y * 2.5;
            cost = z + 7;
        } else {
            cost = 0; // Or whatever you want to set it to in this case
        }
    } else {
        cost = 0; // Or whatever you want to set it to in this case
    }
    System.out.println(cost);
}

或预初始化成本值:

public static void main(String[] args) {
    Scanner in = new Scanner(System.in);

    double mailWeight;
    double cost = 0; // Or whatever you want it to be if none of the cases match

    System.out.println("How much does your mail weigh (g)");
    mailWeight = in.nextDouble();

    in.close();

    if (mailWeight > 0 && mailWeight <= 30) {
        cost = 4;
    } else if (mailWeight > 30 && mailWeight <= 50) {
        cost = 5.50;
    } else if (mailWeight > 50) {
        double x = mailWeight - 100;
        if (x >= 50) {
            double y = x/50;
            Math.ceil(y);
            double z = y * 2.5;
            cost = z + 7;
        }
    }
    System.out.println(cost);
}

除了variable not initialized问题,还有一些地方需要改进:

  1. 删除多余的检查
  2. 修复超重成本的计算
  3. Scanner基于System.in不需要关闭
Scanner in = new Scanner(System.in);
System.out.println("How much does your mail weigh (g)");

double mailWeight = in.nextDouble();
double cost;

if (mailWeight <= 0) {
    cost = 0;
} else if (mailWeight <= 30) {
    cost = 4;
} else if (mailWeight <= 50) {
    cost = 5.50;
} else {
    cost = 7;

    if (mailWeight > 100) {
        double y = Math.ceil((mailWeight - 100) / 50.0);
        cost += 2.5 * y;
    }
}
System.out.println(cost);