3

我刚刚接触 Java 语言,所以我通常会遇到一些平庸的错误。以下应该是其中之一。Es1.java:93: error: variable f may not have been initialized 在查看代码之前要知道的事情 - 我正在使用一些自定义类:ConsoleInputManager 和 ConsoleOutputManager 的工作原理与 Scanner 和 System.out 基本相同;图是一个抽象类;圆形、方形和矩形扩展图

import prog.io.*;
//ConsoleInputManager, ConsoleOutputManager
import prog.utili.*;
//Figure, Circle, Squade, Rectangle
class Es1{
public static void main(String[] args){

//Variables
ConsoleInputManager in = new ConsoleInputManager();
ConsoleOutputManager out = new ConsoleOutputManager();
int com1,com2,com3;
com1 = com2 = com3 = 0;
double r,s,l,w;
r = s = l = w = 0.0;
Figure f;

do{
    //Menu
    out.println("1. Insert a new figure");
    out.println("2. Calculate the area of the current figure");
    out.println("3. Examine the current figure");
    out.println("4. Exit the program\n");

    //Input
    com1 = in.readInt("Command: ");

    //New figure
    if (com1 == 1){
        do{
            out.println("1. Circle");
            out.println("2. Square");
            out.println("3. Rectangle");
            out.println("4. Back to main menu\n");
            com2 = in.readInt("Command: ");
            //Circle
            if (com2 == 1){
                s = l = w = 0.0;
                do{
                    r = in.readDouble("Radius: ");
                } while (r <= 0);
            }
            else
            //Square
            if (com2 == 2){
                r = l = w = 0.0;
                do{
                    s = in.readDouble("Side: ");
                } while (s <= 0);
            }
            else
            //Rectangle
            if (com2 == 3){
                r = s = 0.0;
                do{
                    l = in.readDouble("Length: ");
                } while (l <= 0);
                do{
                    w = in.readDouble("Width: ");
                } while (w <= 0);
            }
        } while (com2 != 4);
    }
    else

    //Area
    if (com1 == 2){
        if (r != 0.0){
            f = new Circle(r);
            out.println("Area = " + f.getArea());
        }
        else
        if (l != 0.0){
            f = new Square(s);
            out.println("Area = " + f.getArea());
        }
        else
        if ( b != 0.0){
            f = new Rectangle(l,w);
            out.println("Area = " + f.getArea());
        }
        else
            out.println("It hasn't been inserted any figure");
    }
    else

    //Examination
    if (com1 == 3){
        do{
            out.println("1. Examine the current figure");
            out.println("2. Back to main menu");
            com3 = in.readInt("Command: ");
            if (com3 == 1){
                if (f instanceof Circle)
                    out.println("Circle");
                else
                if (f instanceof Square)
                    out.println("Square");
                else
                if (f instanceof Rectangle)
                    out.println("Rectangle");
                else
                    out.println("It hasn't been inserted any figure");
            }   
        } while (com3 != 2);
    }

} while (com1 != 4);
}
}
4

2 回答 2

5
Figure f;

上面的语句是内部main方法。有可能不满足 if/else 条件,从而使 f 未分配。

将其更改为如下所示:

Figure f=null;

所有局部变量都需要在使用之前分配一些值。

除此之外,请确保在对 f 执行任何操作之前执行 null 检查。

于 2012-11-30T16:27:04.930 回答
0

Figure f;

这未初始化。

于 2012-11-30T16:29:50.810 回答