这篇文章给大家介绍Ruby对象模型是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
公司主营业务:成都网站设计、成都网站制作、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出晋安免费做网站回馈大家。
对象模型的7条规则:
只有一种对象——要么普通对象,要么模块
只有一种模块——要么普通模块、类、eigenclass(单件类)或代理类
只有一个方法——存在于一种模块之中——通常在类中
每个对象(包括类)都有自己“真正的类”——要么普通类、要么eigenclass
除了BasicObject类无超类外,每个类有且只有一个超类,即任何类只有一条向上直到BasicObject的祖先链
一个对象的eigenclass的超类是这个对象的类;一个类的eigenclass的超类是这个类的超类的eigenclass
当调用一个方法是,Ruby先向后进入接受者真正的类,然后再向上进入祖先链查找方法
根据Ruby对象模型的基础来说:由类所派生出来的实例仅仅是一个类的引用,实例中仅仅存储了自己运行过程中所使用到的实例变量(若是仅仅在类定义时声明而应用运行过程中又完成没有使用到的话,实例中甚至都不会有定义和存储当初声明的实例变量),而所有的方法都是从类中引用,被调用时会寻着祖先链向上查找。
那么,在
def obj.my_singleton_method; end
这样的一种场景之下,我们定义的my_singleton_method()根本就没有容身之处:
首先,他不能存在于实例之中,因为实例中的方法都是循着祖先链查找的。
再者,他也不能存在于他的类中,不然这个方法就会变成一个公共方法,所有这个类派生出来的实例都可以使用。
因此,当一个对象索引类的时候,能看到的并非是当初所定义的类,而是一个对象特有的隐藏类。这个类称为对象的eigenclass。
访问器家族: attr_accessor()、attr_reader()、attr_writer() / Module#attr_*
Ruby的对象中并没有属性,因此对象的属性定义是通过实例变量+拟态方法的形式实现。
当需要定义过多的属性的时候哦,就重复输入大量枯燥的代码。采用类宏可以用简单的声明的方式自动生成对应属性的拟态方法。
应用中,可以通过类宏以及动态方法的形式,在规范函数命名规则的同时兼容旧方法并且还可以加入提醒声明的功能。
class Book attr_accessor :title, :subtitle def lend_to(user) puts "Lending to #{user}" #... end def self.deprecate(old_method, new_method) define_method(old_method) do |*args, &block| warn "Warning: #{old_method}() is deprecated. Please use #{new_method}()." send(new_method, *args, &block) end end deprecate :Get_Title, :title deprecate :Set_Title, :title= deprecate :Lend_to_user, :lend_to deprecate :title2, :subtitle deprecate :title2=, :subtitle= end
类方法的定义 在Ruby中,类是模块的一种特列。常用的定义类方法的方式有两种:
class Myclass def Myclass def self.class_method #... end end end def Myclass.class_method #... end
但由于类方法其实是该类存储在eigenclass中的单件方法,因此除了上面的方法之外,我们也可以通过打开这个eigenclass并在那里定义方法:
class Myclass class << self def class_method #this is a class_method too end end end
关于Ruby对象模型是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。