以下是可用于解决这个问题的示例代码,并解释了Groovy元编程行为不一致的原因:
class Person {
String name
Integer age
}
Person.metaClass {
getSomething = { ->
// This method will be added to all instances of Person
return "Something"
}
}
def p1 = new Person(name: "John", age: 30)
assert p1.getSomething() == "Something"
def p2 = new Person(name: "Jane", age: 25)
assert p2.getSomething() == "Something"
def p3 = new Person(name: "Jack", age: 40)
assert p3.getSomething() == "Something"
p1.metaClass.getSomething = { ->
// This method will only be added to p1 instance
return "Something else"
}
assert p1.getSomething() == "Something else"
assert p2.getSomething() == "Something"
assert p3.getSomething() == "Something"
在上面的示例中,我们为“Person”类添加了一个名为“getSomething”的方法,该方法将添加到该类的所有实例中。然后,我们通过更改p1实例的元类来添加不同的“getSomething”方法,该方法仅适用于p1。
但是,在Groovy中,如果我们更改了元类之后,所有具有相同类型的其他对象也将共享相同的元类。这是因为在Groovy中,类的元类是在第一次对该类进行操作时创建的。如果我们尝试将元类附加到一个新对象,那么它将仅反映最新的更改。所以我们看到,p2和p3仍然具有通用的“getSomething”方法。
上一篇:不一致的git子模块远程URL