這篇文章給大家介紹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對象模型是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。