对于我的项目,我有很多对象分为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
。
但是,这个稍微改变的代码产生Unresolved compilation problem
case expressions must be constant expressions
。
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语句),它可以处理这两个枚举中出现的所有情况。
EDIT2:
所以这里。我有10个类(C1, C2, ..., C10)
和这些类的大约40个对象。其中一些对象是所谓的所有者,有些是共享的。每个共享对象都有一个所有者(这是基本关系 - 它与java继承没有任何关系)。
现在每个共享对象obj
都会不时更改,而obj
需要询问其所有者own
是否可以更改(这只是其中一项操作)然后它改变(并再次通知所有者)。对象obj
也有一组预定义的操作,由C1
在enum
中定义。因此own
必须具有类C1
的对象操作的处理函数。现在我们有一个对象obj2
,该对象属于C2
类,具有不同的操作集和相同的所有者own
。 obj
可能只执行C1
中定义的操作,而obj2
可能只执行C2
中定义的操作。
如何概括处理功能以便整齐地编写?我应该使用枚举吗?
答案 0 :(得分:4)
您只能在switch语句中使用编译时已知的常量。这是因为切换代码是静态检查和构建的。
在第二种情况下你可以做到
static
{
foo=8;
bar=foo;
}
但由于这些值在运行时才知道,因此无法构建switch语句或检查它是否正确。
答案 1 :(得分:2)
static variables or blocks or methods
。
您的问题是在编译时间,这是在加载/初始化课程之前。所以字段是最终的,它们不是初始化的(当然是在编译时)。
在第一种情况下,foo
和bar
的值在编译时是已知的。
答案 2 :(得分:0)
我建议使用枚举。这样就不再需要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");
}
}
}
答案 3 :(得分:0)
或者只是使用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){
}
}