提及鏈式編程和函數式編程,小夥伴們千萬沒關係張。編程
聽着很高大尚,其實也就那麼回事。相信有過C#開發經驗的,或者其餘編程經驗的,只要不是OC,一看就知道。函數式編程
看兩行代碼:函數
1 Person *person = [[Person alloc] init]; 2 person.run(9.2).eat(@"香蕉").run(1.2).eat(@"麪條");
上面的就是鏈式編程+函數式編程。spa
來個大白話解釋:看到括號裏面的參數了吧,跟C的函數調用是否是很類似,包括別的語言,都用小括號傳參,只有OC是冒號傳參。code
再看方法調用用的是".",而OC用的是[]+空格。對象
這幾個方法調用,若是要按OC的打法,估計要整4行,對象一個一個的調用方法,但鏈式就是這麼一行搞定。blog
咱們來分析一下,在OC中,什麼能夠經過小括號()來傳參呢,沒錯,那就是Block,調用Block的時候,blockName(para),就是這樣。開發
因此,咱們推斷run(para)和eat(para)這兩個方法,確定返回值是一個Block,並且是帶一個參數的Block。get
那麼經過 《點》 調用方法怎麼解釋呢? 點其實就是調用getter方法,因此run和eat方法沒有參數,只有一個返回類型爲Block的值。it
並且,能一直點下去,說明什麼呢,說明Block也有返回值啊,並且返回值的類型就是當前對象的類型。
哈哈,這下明白了吧。
原理說明白了,咱們上代碼吧:
Person類頭文件:
1 #import <Foundation/Foundation.h> 2 3 @interface Person : NSObject 4 5 // 函數的返回值是一個Block,Block的返回值是當前對象,Block有一個參數 6 - (Person *(^)(double distance))run; 7 8 // 函數的返回值是一個Block,Block的返回值是當前對象,Block有一個參數 9 - (Person *(^)(NSString *food))eat; 10 11 @end
Person類的.m文件:
1 #import "Person.h" 2 3 @implementation Person 4 5 - (Person *(^)(double))run{ 6 // 方法的返回是一個」有參無返回值的Block「 7 return ^(double distance){ 8 NSLog(@"跑:%f",distance); 9 // block的返回值是當前對象 10 return self; 11 }; 12 } 13 14 - (Person *(^)(NSString *))eat{ 15 // 方法的返回是一個」有參無返回值的Block「 16 return ^(NSString *food){ 17 NSLog(@"吃:%@",food); 18 // block的返回值是當前對象 19 return self; 20 }; 21 } 22 23 @end
看到了吧,必定要看這2行註釋,這但是整個的核心。
接下來,調用便可。
1 #import "ViewController.h" 2 #import "Person.h" 3 4 @interface ViewController () 5 6 @end 7 8 @implementation ViewController 9 10 - (void)viewDidLoad { 11 [super viewDidLoad]; 12 13 Person *person = [[Person alloc] init]; 14 15 // 這就是鏈式編程+函數式編程 16 person.run(9.2).eat(@"香蕉").run(1.2).eat(@"麪條"); 17 } 18 19 @end