为每个新的 Class 分配唯一 ID(不是实例!)
Assign unique ID for every new Class (not instance!)
我想知道是否可以为每个新 class(不是实例!)分配一个唯一 ID。
我的意思的例子:
public class ChildObjectOne extends SuperClass {}
public class ChildObjectTwo extends SuperClass {}
public SuperClass {
private final int ID;
public SuperClass() {
this.ID = newID();
}
}
final ChildObjectOne childObjectOne = new ChildObjectOne();
final ChildObjectTwo childObjectTwo = new ChildObjectTwo();
System.out.println(childObjectOne.getID()); //prints 1
System.out.println(childObjectOne.getID()); //prints 2
childObjectOne = new ChildObjectOne();
childObjectTwo = new ChildObjectTwo();
System.out.println(childObjectOne.getID()); //prints 3
System.out.println(childObjectOne.getID()); //prints 4
我想让它做的是再次打印 1 和 2。它应该为每个新的 class 生成一个新的 ID,但是如果我创建那个 class 的新实例,我希望 ID 保持不变。
我尝试使用泛型来实现:
public SuperClass<T> {
private static int ID;
public SuperClass() {
this.ID = newID();
}
}
public class ChildObjectOne extends SuperClass<ChildObjectOne> {}
public class ChildObjectTwo extends SuperClass<ChildObjectTwo> {}
我本来希望,它会把传递一个不同的 T 作为一个新的 class,但这没有用。相反,ID 是最后设置的。
如何实现这种ID系统?
Class::getName
Java 中的每个 class 已经带有一个唯一标识符:class 的 fully-qualified name。无需您添加标识符。
通过调用 Class::getName
访问完全限定名称。
对于 class:
String.class.getName()
"java.lang.String"
对于对象(实例),调用Object::getClass
,然后Class::getName
。
customer.getClass().getName()
com.example.invoicing.Customer
为了扩展我的评论,class 名称将为您提供一个唯一的字符串 ID。如果您希望该 ID 是一个数字,您可以这样做:
class IdGenerator{
private static int counter = 0;
private static HashMap<String,Integer> classIdMap = new HashMap<>();
public static synchronized int getId(Class clazz){
if (classIdMap.containsKey(clazz.getName())) {
return classIdMap.get(clazz.getName());
} else {
classIdMap.put(clazz.getName(), ++counter);
return counter;
}
}
}
然后从你的 class 你会做:
IdGenerator.getId(this.getClass());
每次 运行 您的应用程序生成的 ID 可能不相同 ,具体取决于它的结构。
例如:
Scanner in = new Scanner(System.in);
if (in.nextInt() < 100) {
System.out.println("a = " + new Aclass().id); // a = 1
System.out.println("b = " + new Bclass().id); // b = 2
} else {
System.out.println("b = " + new Bclass().id); // b = 1
System.out.println("a = " + new Aclass().id); // a = 2
}
我想知道是否可以为每个新 class(不是实例!)分配一个唯一 ID。
我的意思的例子:
public class ChildObjectOne extends SuperClass {}
public class ChildObjectTwo extends SuperClass {}
public SuperClass {
private final int ID;
public SuperClass() {
this.ID = newID();
}
}
final ChildObjectOne childObjectOne = new ChildObjectOne();
final ChildObjectTwo childObjectTwo = new ChildObjectTwo();
System.out.println(childObjectOne.getID()); //prints 1
System.out.println(childObjectOne.getID()); //prints 2
childObjectOne = new ChildObjectOne();
childObjectTwo = new ChildObjectTwo();
System.out.println(childObjectOne.getID()); //prints 3
System.out.println(childObjectOne.getID()); //prints 4
我想让它做的是再次打印 1 和 2。它应该为每个新的 class 生成一个新的 ID,但是如果我创建那个 class 的新实例,我希望 ID 保持不变。
我尝试使用泛型来实现:
public SuperClass<T> {
private static int ID;
public SuperClass() {
this.ID = newID();
}
}
public class ChildObjectOne extends SuperClass<ChildObjectOne> {}
public class ChildObjectTwo extends SuperClass<ChildObjectTwo> {}
我本来希望,它会把传递一个不同的 T 作为一个新的 class,但这没有用。相反,ID 是最后设置的。
如何实现这种ID系统?
Class::getName
Java 中的每个 class 已经带有一个唯一标识符:class 的 fully-qualified name。无需您添加标识符。
通过调用 Class::getName
访问完全限定名称。
对于 class:
String.class.getName()
"java.lang.String"
对于对象(实例),调用Object::getClass
,然后Class::getName
。
customer.getClass().getName()
com.example.invoicing.Customer
为了扩展我的评论,class 名称将为您提供一个唯一的字符串 ID。如果您希望该 ID 是一个数字,您可以这样做:
class IdGenerator{
private static int counter = 0;
private static HashMap<String,Integer> classIdMap = new HashMap<>();
public static synchronized int getId(Class clazz){
if (classIdMap.containsKey(clazz.getName())) {
return classIdMap.get(clazz.getName());
} else {
classIdMap.put(clazz.getName(), ++counter);
return counter;
}
}
}
然后从你的 class 你会做:
IdGenerator.getId(this.getClass());
每次 运行 您的应用程序生成的 ID 可能不相同 ,具体取决于它的结构。 例如:
Scanner in = new Scanner(System.in);
if (in.nextInt() < 100) {
System.out.println("a = " + new Aclass().id); // a = 1
System.out.println("b = " + new Bclass().id); // b = 2
} else {
System.out.println("b = " + new Bclass().id); // b = 1
System.out.println("a = " + new Aclass().id); // a = 2
}