對(duì)于runtime機(jī)制,在網(wǎng)上找到的資料大概就是怎么去用這些東西,以及查看runtime.h頭文件中的實(shí)現(xiàn),當(dāng)然這確實(shí)是一種很好的學(xué)習(xí)方法,但是,其實(shí)我們還是不會(huì)知道runtime底層編譯成C++語(yǔ)言之后做了什么? 查到一個(gè)大牛給資料,頓時(shí)對(duì)runtime有了一定認(rèn)識(shí)!
我們隨便寫(xiě)一個(gè)小程序,代碼如下: person類(lèi)頭文件如下,
#import <Foundation/Foundation.h>
Person實(shí)現(xiàn):
@interface Person : NSObject
@property (nonatomic, strong) NSString *name; @property (nonatomic, assign) int age;
@end
main.m文件如下:
int main(int argc, const char *argv[]) {
Person *p = [[Person alloc] init];
NSString *str = @"zhangsan";
p.name = str;// p.name 等價(jià)于[p setName:str];
p.age = 20;
return 0;
}
然后我們打開(kāi)終端,在命令行找到cd到文件目錄,然后中輸入:
clang -rewrite-objc main.m
命令可以將main.m編譯成C++的代碼,改成不同的文件名,就會(huì)生成不同的c++代碼 這是就生成了main.cpp這個(gè)c++文件,打開(kāi)文件代碼 查看該main.cpp最底下的main函數(shù), 這樣我們就可以看到底層具體實(shí)現(xiàn)的方式!
這時(shí),我們就需要知道這些方法: objc_msgSend 可以給對(duì)象發(fā)送消息 objc_getClass("Person") 可以獲取到指定名稱(chēng)的對(duì)象 sel_registerName("alloc") 可以調(diào)用到對(duì)象的方法
通過(guò)查看,c++代碼,我們得出結(jié)論: 使用objc_msgSend函數(shù),給objc_getClass函數(shù)實(shí)例化的對(duì)象發(fā)送sel_registerName獲取到的方法 這么一個(gè)消息 代碼是給人看的,順帶讓機(jī)器實(shí)現(xiàn)功能。日常的程序開(kāi)發(fā)過(guò)程中,要少用runtime,
那什么時(shí)候會(huì)使用runtime呢? runtime應(yīng)用的時(shí)機(jī):
- 1、當(dāng)需要非常高的性能開(kāi)發(fā)時(shí),使用runtime,注釋?zhuān)簅c的代碼已經(jīng)無(wú)法滿(mǎn)足性能需求;
- 2、當(dāng)我們對(duì)系統(tǒng)內(nèi)部的實(shí)現(xiàn)很好奇的時(shí)候,可以用clang反編譯成c++去看底層的實(shí)現(xiàn)機(jī)制!
項(xiàng)目講解的是runtime的底層實(shí)現(xiàn)原理, 如果想要知道runtime是怎么用的,可以查看runtime.h頭文件查看! 以下是runtime機(jī)制方法的一些使用方法介紹,希望對(duì)大家有用! 相關(guān)技術(shù)文檔:http://www.tuicool.com/articles/uimInm http://blog.csdn.net/lengshengren/article/details/17764135