#Worked Time.now
我理解为这是调用类[Time]实例的方法[now].然后我尝试自己调用该方法:
#Failed now
并且失败了,我假设虽然可以在一般范围[作为全局对象的一部分]创建方法,但如果它依赖于“父”类的初始化变量,则它不能单独调用,因为它会不知道搜索那些初始化变量的对象.之后我创建了一个测试类:
class Clock def initialize @hours = 1 @minutes = 30 end def showTime puts "The time is: #{@hours}:#{@minutes}" end end #this worked watch = Clock.new watch.showTime #this failed showTime
然后我创建了一个基本方法(假设它在全局级别)
def mymethod puts "The mighty METHOD!" end #Works mymethod
并按照我的方式调用此方法,而不引用全局对象.所以…我的问题如下:
>如何以这种方式调用[Time.now]?不应该首先创建时间实例吗?
>为什么我不能单独调用[now]方法?我是对的,它依赖于以这种方式调用时无法找到的资源吗?
>为什么我不能单独调用showTime方法?但是如果我在“全局”级别定义任何方法,我可以在不引用全局对象的情况下访问它
每个方法都必须是某个接收器的实例方法.
全局方法被定义为Object类上的私有实例方法,因此似乎是全局可用的.为什么?从任何上下文Object总是在self的类层次结构中,因此Object上的私有方法总是可以在没有receiver的情况下调用.
def fuuuuuuuuuuun end Object.private_methods.include?(:fuuuuuuuuuuun) # => true
类方法被定义为其类实例的“单例类”上的实例方法. Ruby中的每个对象都有两个类,一个是“单例类”,实例方法只适用于那个单个对象,一个“普通类”,带有该类所有对象的方法.类没有什么不同,它们是Class类的对象,可能有单例方法.
class A class << self # the singleton class def example end end end A.singleton_class.instance_methods.include?(:example) # => true
定义类方法的替代方法是
class A def self.example end end # or def A.example end
有趣的是,您可以使用相同的语法def(接收器)定义任何对象(不仅仅是类对象)上的单例方法.(方法名称)如下
str = "hello" def str.square_size size * size end str.square_size # => 25 "any other string".square_size # => raises NoMethodError
一些编程语言历史 – Singleton类来自Smalltalk语言,它们被称为“元类”.基本上Ruby中的所有面向对象特性(以及Enumerable上的函数式枚举器)都取自Smalltalk语言. Smalltalk是一种早期基于类的面向对象语言,创建于70年代.它也是发明图形用户界面的语言,如重叠窗口和菜单等.如果你喜欢Ruby也可以看看Smalltalk,你可能会再次坠入爱河.