我正在尝试在 Groovy 中修改 JSONObject 的元类,以使其行为尽可能像常规的 Groovy 映射。当我在元类中实现方法时,其中一些方法很简单,例如下面示例中的 JSONObject.metaClass.size。JSONObject 有一个 length() 方法,我只是将它连接到一个新的 size() 方法,但有些方法有特殊含义。例如,要使下标分配起作用,我必须重写 propertyMissing,而不是 putAt。看起来很多收集操作,如 each、collect、findAll 等都是相似的。
我的第一个问题是在这种情况下我需要覆盖哪些特殊方法才能使 each() 工作?我的第二个问题是我自己如何找出答案?在某处是否有从 MOP 获得特殊待遇的方法的参考?我尝试查看 groovy-core 源代码,但其中有很多内容,我不知道从哪里开始。
JSONObject.metaClass.propertyMissing = { String name, newValue -> delegate.put(name, newValue) }
JSONObject.metaClass.size = { -> delegate.length() }
JSONObject.metaClass.each = { cl -> delegate.keys().collectEntries{ [(it): delegate[it] ]}.each(cl) }
def json = new JSONObject()
json['a'] = 999
json.b = 2.2
json['c'] = 'the letter C'
println json['a'] // Prints 999
println json['b'] // Prints 2.2
println json.c // 'the letter C'
println json.size() // Prints 3
//No signature of method: ... $__spock_feature_0_0_closure4.doCall() is applicable
json.each{ k,v -> println "$k = $v"}