Ruby可以打开一个对象,但能够打开一个函数么?
Ruby打开一个对象的meta class并向其中重写方法,比如:
这是定义TT2这个类
下面向TT2这个类对象添加一个新的out方法
[b]问题来了:[/b]
以上操作都是在类层面方法外面做的hack,如果我想把这句代码p "new out" 直接放到原来的out方法体内,比如我打算放到out方法的最后一行该怎么办?
需求是这样的:
有一个第三方的库,里面有个私有方法并不符合我的需求,我想hack一下得到这个方法体中的一个对象,这个对象只存在与这个函数空间内,所以我只能hack这个方法。
但是:1、我不想更改这个库的源代码,为了保持通用性。2、它这个方法太长了,我不想整段copy从而再写个一样的方法然后类似这样alias_method :_out,:out的,把原来方法覆盖掉。
ruby中大多数东西都是对象都是类,只是ruby不像javascript,js中函数也是一个对象,ruby中函数不是对象,如果ruby中函数也是对象的话,我想我是否也可以用class << Function;#code;end这样的操作打开我想操作的函数了?
Ruby打开一个对象的meta class并向其中重写方法,比如:
这是定义TT2这个类
class TT2
class << self
def pa
out
end
def out(a)
p a
end
private :out
end
end
下面向TT2这个类对象添加一个新的out方法
class << TT2
alias_method :_out,:out
def out(a)
p "new out"
_out(a)
end
end
[b]问题来了:[/b]
以上操作都是在类层面方法外面做的hack,如果我想把这句代码p "new out" 直接放到原来的out方法体内,比如我打算放到out方法的最后一行该怎么办?
需求是这样的:
有一个第三方的库,里面有个私有方法并不符合我的需求,我想hack一下得到这个方法体中的一个对象,这个对象只存在与这个函数空间内,所以我只能hack这个方法。
但是:1、我不想更改这个库的源代码,为了保持通用性。2、它这个方法太长了,我不想整段copy从而再写个一样的方法然后类似这样alias_method :_out,:out的,把原来方法覆盖掉。
ruby中大多数东西都是对象都是类,只是ruby不像javascript,js中函数也是一个对象,ruby中函数不是对象,如果ruby中函数也是对象的话,我想我是否也可以用class << Function;#code;end这样的操作打开我想操作的函数了?