zoukankan      html  css  js  c++  java
  • 详细讲解委托和协议、看了这个我顿悟很经典!

    转:http://blog.sina.com.cn/s/blog_4cd8dd130100uqui.html

    Objective-C委托协议是本文要介绍的内容,委托协议是两个概念,协议实际上相当于C++中的纯虚类的概念,只定义并只能由其它类来实现。而委托类似于Java中的接口。(Objective-C实现委托这种机制是利用协议来实现的,这种说法我现在认为是不对的,理由下述:)。

    Objective-C委托和协议本没有任何关系,协议如前所述,就是起到C++中纯虚类的作用,对于“委托”则和协议没有关系,只是我们经常利用协议还实现委托的机制,其实不用协议也完全可以实现委托。下面说明了实现方式:

    定义一个类A:

     
    1. @interface A:NSObject 
    2. -(void)print; 
    3. @end 
    4. @implement
    5. -(void)print{ 
    6. @end

    定义一个类B,在B中定义类A的实例为B中的成员变量:

     
    1. @interface B:NSObject{ 
    2. A *a_delegate; 
    3. @end

    下面在mai()函数中实现委托机制:

     
    1. void main() 
    2. B *b=[[B alloc]init]; 
    3. A *a=[[A alloc]init]; 
    4. b.a_delegate=a; 
    5. [b.a_delegate print]; 
    6. }

    这样,最基本的委托机制就完成了,套用最通俗的一句解释:B需要完成一个print的操作,但他自己并没有实现这个操作,而是交给了A去完成,自己只是在需要时调用A中实现的print操作。

    下面再写一种实现方式,这样方式更接近于我们通常见到的用协议还实现的方式:

    我们还是定义一个类A:

     
    1. @interface A:NSObject{ 
    2. B *b; 
    3. -(void)print; 
    4. @end 
    5. @implement
    6. @synasize delegate; 
    7. -(void)viewDidLoad{ 
    8. b=[[B alloc]init]; 
    9. b.delegate=self
    10. -(void)print{ 
    11. NSLog(@"print was called"); 
    12. @end

    然后类B的定义改成如下所示:

     
    1. @interface B:NSObject{ 
    2. id delegate 
    3. @propert(nonamtic,retain) id delegate; 
    4. @end 
    5. 现在我们不用main()函数,在B的实现部分来实现委托机制: 
    6. @implement
    7. -(void)callPrint{ 
    8. [self.delegate print]; 
    9. @end

    上面这种实现方式和第一种其实是一样的,只是第一种是在第三方函数调用委托方法。delegate是id类型,本例中就是A类的一个实例,当然可以调用A类中的print。第二种方式不存在第三方函数,是在B类中调用 A类中的方法。或者说,B中需要print方法,自己不实现,让A来实现,自己调用 。

    再接下来就是最常见的用协议实现委托的方式,说明如下:

    protocol-协议,就是使用了这个协议后就要按照这个协议来办事,协议要求实现的方法就一定要实现。

    delegate-委托,顾名思义就是委托别人办事,就是当一件事情发生后,自己不处理,让别人来处理。

    当一个A view 里面包含了B view

    b view需要修改a view界面,那么这个时候就需要用到委托了。

    需要几个步骤

    1、首先定一个协议

    2、a view实现协议中的方法

    3、b view设置一个委托变量

    4、把b view的委托变量设置成a view,意思就是 ,b view委托a view办事情。

    5、事件发生后,用委托变量调用a view中的协议方法

    例子:

     
    1. B_View.h: 
    2. @protocol UIBViewDelegate <NSObject>
    3. @optional 
    4. - (void)ontouch:(UIScrollView *)scrollView; //声明协议方法 
    5. @end 
    6. @interface BView : UIScrollView<UIScrollViewDelegate>
    7. id< UIBViewDelegate > _touchdelegate; //设置委托变量 
    8. @property(nonatomic,assign) id< UIBViewDelegate > _touchdelegate;  
    9. @end 
    10. B_View.mm: 
    11. @synthesize _touchdelegate; 
    12. - (id)initWithFrame:(CGRect)frame
    13. if (self = [super initWithFrame:frame])
    14. // Initialization code 
    15. _touchdelegate=nil
    16. return self; 
    17. - (void) touchesBegan:(NSSet*)touches withEvent:(UIEvent*)event 
    18. [super touchesBegan:touches withEvent:event]; 
    19. if(_touchdelegate!=nil && [_touchdelegate respondsToSelector: @selector(ontouch:) ] == true)  
    20. [_touchdelegate ontouch:self]; //调用协议委托 
    21. @end 
    22. A_View.h: 
    23. @interface AViewController : UIViewController < UIBViewDelegate >
    24. BView *m_BView; 
    25. @end 
    26. A_View.mm: 
    27. - (void)viewWillAppear:(BOOL)animated 
    28. m_BView._touchdelegate = self; //设置委托 
    29. [self.view addSubview: m_BView]; 
    30. - (void)ontouch:(UIScrollView *)scrollView 
    31. //实现协议 
    32. }

    小结:详解Objective-C委托协议的内容介绍完了,希望通过本本文的学习能对你有所帮助!

  • 相关阅读:
    模块化利器:RequireJS常用知识
    移动端适配:font-size设置的思考
    样式化复选框
    jquery tmpl 详解
    移动前端相关解决方案整理
    常用页面布局方式介绍
    移动端制作的常见问题及解决方法
    手机端页面自适应:rem布局
    React工程化之PWA之serviceWorker
    React之JSX循环遍历方法对比
  • 原文地址:https://www.cnblogs.com/jackljf/p/3588944.html
Copyright © 2011-2022 走看看