對于runtime機制,在網上找到的資料大概就是怎么去用這些東西,以及查看runtime.h頭文件中的實現(xiàn),當然這確實是一種很好的學習方法,但是,其實我們還是不會知道runtime底層編譯成C++語言之后做了什么?
查到一個大牛給資料,頓時對runtime有了一定認識!
我們隨便寫一個小程序,代碼如下:
person類頭文件如下,
#import
@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 等價于
[p setName:str];
p.age = 20;
return 0;
}
然后我們打開終端,在命令行找到cd到文件目錄,然后中輸入:
clang -rewrite-objc main.m
命令可以將main.m編譯成C++的代碼,改成不同的文件名,就會生成不同的c++代碼
這是就生成了main.cpp這個c++文件,打開文件代碼
查看該main.cpp最底下的main函數,
這樣我們就可以看到底層具體實現(xiàn)的方式!
這時,我們就需要知道這些方法:
objc_msgSend 可以給對象發(fā)送消息
objc_getClass(“Person”) 可以獲取到指定名稱的對象
sel_registerName(“alloc”) 可以調用到對象的方法
通過查看,c++代碼,我們得出結論:
使用objc_msgSend函數,給objc_getClass函數實例化的對象發(fā)送sel_registerName獲取到的方法
這么一個消息
代碼是給人看的,順帶讓機器實現(xiàn)功能。日常的程序開發(fā)過程中,要少用runtime,
那什么時候會使用runtime呢?
runtime應用的時機:
1> 當需要非常高的性能開發(fā)時,使用runtime,注釋:oc的代碼已經無法滿足性能需求
2> 當我們對系統(tǒng)內部的實現(xiàn)很好奇的時候,可以用clang反編譯成c++去看底層的實現(xiàn)機制!
最后,我知道我寫的這篇博客可能不是很好,或者讀者覺得有什么不對的地方,希望能給我指出來,大家共同進步!
項目講解的是runtime的底層實現(xiàn)原理, 如果想要知道runtime是怎么用的,可以查看runtime.h頭文件查看!
以下是runtime機制方法的一些使用方法介紹,希望對大家有用!
相關技術文檔:
更多信息請查看IT技術專欄
2025國考·省考課程試聽報名