鏈式編程和函數式編程

提及鏈式編程和函數式編程,小夥伴們千萬沒關係張。編程

聽着很高大尚,其實也就那麼回事。相信有過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
相關文章
相關標籤/搜索