switch 语句并在静态块中初始化最终静态变量



对于我的项目,我将许多对象分成 10 个类。每个对象都可以执行一些操作,这些操作必须事先注册(每个类只注册一次操作(。为每个类定义的操作表示为public final static整数。我想在运行时动态分配操作的 ID(每个类的操作数目前约为 20 个,并且数量会增加(。

当执行操作并且我必须找到正在执行的操作时,问题出现了(我使用 switch 语句(。

下面是一个工作代码的简单示例:

public class Test {
    final static int foo = 8;
    final static int bar = 10;
    public static void main(String[] args)
    {
        int x=10;
        switch(x)
        {
        case foo:
            System.out.println("FOO");
            break;
        case bar:
            System.out.println("BAR");
            break;
        default:
            System.out.println("PROBLEM");
        }
    }
}

此代码通常编译并显示BAR .

但是这个稍微转换的代码会产生一个带有case expressions must be constant expressionsUnresolved compilation problem

public class Test {
    final static int foo;
    final static int bar;
    static
    {
        foo=8;
        bar=10;
    }
    public static void main(String[] args)
    {
        int x=10;
        switch(x)
        {
        case foo:
            System.out.println("FOO");
            break;
        case bar:
            System.out.println("BAR");
            break;
        default:
            System.out.println("PROBLEM");
        }
    }
}

这些代码实际上不应该工作和编译相同吗?在解决此问题之前,我无法动态执行任何操作?还是其他方法?

谢谢

编辑:由于使用枚举的想法,我想解决这个问题:

public class Test {
  enum OperationSet1 {
    FOO, BAR, THESE, ARE, ALL, DIFFERENT, OPERATIONS
  }
  enum OperationSet2 {
    FOO, BAR, NOW, SOME, OTHER, OPS
  }
  public static void main(String[] args) {
    OperationSet1[] ops = new OperationSet1[10];
    for (int i=0; i<ops.length; i++)
      ops[i] = OperationSet1.values()[(int)(Math.random()*OperationSet1.values().length)];
    OperationSet2[] ops2 = new OperationSet2[10];
    for (int i=0; i<ops.length; i++)
      ops[i] = OperationSet2.values()[(int)(Math.random()*OperationSet2.values().length)];
    for (OperationSet1 op:ops)
      handleOperation(op);
  }
    for (OperationSet2 op:ops2)
      handleOperation(op);
  }
  public static void handleOperation(Object? op) {
    switch(op) {
        /**code to handle**/
    }
  }
}

我们有两个枚举,我希望有一个处理函数(最好是带有 switch 语句(,它将处理这两个枚举中的所有情况。

编辑2:所以在这里。我有 10 个类(C1, C2, ..., C10)和大约 40 个这些类的对象。其中一些对象是所谓的所有者,有些是共享的。每个共享对象都有一个所有者(这是基本关系 - 它与 java 继承没有任何关系(。

现在,每个共享对象obj不时更改,此obj需要询问其所有者own它是否会更改(这只是其中一项操作(,然后它更改(并再次通知所有者(。对象obj也有一组预定义的操作,他可以执行这些操作,由enum C1定义。因此own必须有一个处理类C1的对象操作的函数。现在我们有一个对象obj2它是类 C2 的,具有一组不同的操作和相同的所有者ownobj只能执行C1中定义的操作,obj2只能执行C2中定义的操作。

如何概括处理函数以便编写得整齐?我甚至应该使用枚举吗?

只能在 switch 语句中使用编译时已知的常量。这是因为交换机代码是静态检查和构建的。

在第二种情况下,你可以做

static
{
    foo=8;
    bar=foo;
}

但是由于这些值在运行时之前是未知的,因此无法构建 switch 语句或检查它是否正确。

static variables or blocks or methods

类初始化(运行时(时加载。

您的问题出在编译时,这远远早于类的加载/初始化。所以字段是最终的,它们不是初始化的(当然是在编译时(。

在第一种情况下,foobar 的值在编译时是已知的。

我建议为此使用枚举。这样就不再需要 ID 处理了。

public class Test {
  enum Operation {
    FOO, BAR, THESE, ARE, ALL, DIFFERENT, OPERATIONS
  }
  public static void main(String[] args) {
    Operation[] ops = new Operation[10];
    for (int i=0; i<ops.length; i++)
      ops[i] = Operation.values()[(int)(Math.random()*Operation.values().length)];
    for (Operation op:ops)
      handleOperation(op);
  }
  public static void handleOperation(Operation op) {
    switch(op) {
    case FOO:
      System.out.println("FOO");
      break;
    case BAR:
      System.out.println("BAR");
      break;
    case THESE:
      System.out.println("THESE");
      break;
    case ARE:
      System.out.println("ARE");
      break;
    case ALL:
      System.out.println("ALL");
      break;
    case DIFFERENT:
      System.out.println("DIFFERENT");
      break;
    case OPERATIONS:
      System.out.println("OPERATIONS");
      break;
    default:
      System.out.println("PROBLEM");
    }
  }
}

或者简单地使用 if-elseif 大小写:

private final static int ONE = 1;
private final static int TWO = 2;
public static void main(String[] args) {
int value = 1;
  if(value==ONE){
  }
  else if(value==TWO){
  }

}

最新更新