標籤:
OC動態調用
OC的函數調用是訊息發送模式,即在運行時動態調用函數,OC在編譯期可以調用任何函數,只要聲明過這個函數,就不會報錯,在真正啟動並執行時候
才會根據函數的名稱找到對應的函數來調用
[ASPerson SayHello]
編譯時間RunTime會將上述代碼轉化為
objc_msgSend(ASPerson @selector(SayHello))
所有定義的類型都繼承自NSObject,NSObject中存在一個指向Class的指標
Class是指向objc_class結構的函數指標;
struct objc_class{Class isa; Class super_class; const charchar *name; long version; long info; long instance_size; struct objc_ivar_list *ivars; struct objc_method_list **methodLists; struct objc_cache *cache; struct objc_protocol_list *protocols;}
Class isa :Obj對象中包含一個isa,指向一般的Class,這個Class包含一般的變數和對象方法,
一般Class中的isa指向metaClass,靜態Class中儲存的是靜態對象(static)成員和類方法.
Class super_class:指向父類,如果這個類是根類,則為NULL
圖
metaclass中的isa指向根Root metaclass而不是super metaclass
Root metaclass繼承Root class產生,Root metaclass指向的是自身
const char *name: 類名
long version: 類的版本資訊,預設為0
long info:供運行期使用的一些位標識,如CLS_CLASS (0x1L) 表示該類為普通 class ,其中包含對象方法和成員變數;CLS_META (0x2L) 表示該類為 metaclass,其中包含類方法;
long instance_size: 該類的執行個體變數大小(包括從父類繼承下來的執行個體變數);
struct objc_ivar_list *ivars: 指向成員變數結構體的函數指標struct objc_ivar_list { int ivar_count; 成員變數的數量struct objc_ivar ivar_list[1]; objc_ivar中包含一般Class的成員變數}
struct objc_method_list **methodLists :指向方法鏈表結構體的函數指標
struct objc_method_list { struct objc_method_list *obsolete; 已經廢棄的方法int method_count; 方法的數量struct objc_method method_list[1]; 方法鏈表結構體}
struct objc_cache *cache:指向最近使用的方法的指標,下次再訪問的時候回先在cache中尋找
struct objc_cache { unsigned int mask /* total = mask + 1 */; unsigned int occupied; Method buckets[1]; };
struct objc_protocol_list *protocols: 儲存該類遵守的協議
struct objc_protocol_list { struct objc_protocol_list *next; long count; Protocol *list[1]; };
SEL類型:
方法選取器類:可以通過方法的名字找到對應方法的指標,每一個方法都有一個SEL,
如果方法名相同,多個方法對應的SEL還是一樣的
動態調用方法過程:
函數在調用的時候通過isa找到對應的class,然後現在cache表中通過SEL尋找對應method的地址,如果沒有找到,再去method列表
中找,如果還沒有找到,就在superClass中去找,逐級尋找,如果找到了,將這個method地址放在cache中,然後執行這個方法
自學ios開發-------Objective-c動態調用方法筆記