Bar*_*lom 6 reflection function-pointers function actionscript-3
class Foo {
public function bar():void { ... }
}
var clazz:Class = Foo;
// ...enter the function (no Foo literal here)
var fun:Function = clazz["bar"]; // PROBLEM: returns null
// later
fun.call(new Foo(), ...);
Run Code Online (Sandbox Code Playgroud)
做上述事情的正确方法是什么?我想要做的Java相当于:
Method m = Foo.class.getMethod("bar", ...);
m.invoke(new Foo(), ...);
Run Code Online (Sandbox Code Playgroud)
实际代码(含解决方法):
class SerClass {
public var className:String;
public var name:String;
private var ser:String = null;
private var unser:Function = null;
public function SerClass(clazz:Class):void {
var type:XML = describeType(clazz);
className = type.@name;
// determine name
name = type.factory.metadata.(@name=="CompactType").arg.(@key=="name").@value;
// find unserializer
var mdesc:XML = XML(type.method.metadata.(@name=="Unserialize")).parent();
if (mdesc is XML) {
unser = clazz[mdesc.@name];
}
// find serializer
var sdesc:XML = XML(type.factory.method.metadata.(@name=="Serialize")).parent();
if (sdesc is XML) {
ser = sdesc.@name;
}
}
public function serialize(obj:Object, ous:ByteArray):void {
if (ser == null) throw new Error(name + " is not serializable");
obj[ser](ous);
}
public function unserialize(ins:ByteArray):Object {
if (unser == null) throw new Error(name + " is not unserializable");
return unser.call(null, ins);
}
}
Run Code Online (Sandbox Code Playgroud)
Bar*_*lom -1
我的解决方法是存储函数名称而不是Function对象。
var fun:String = "bar";
// later...
new Foo()[fun](...);
Run Code Online (Sandbox Code Playgroud)