1:Block为匿名函数 能够实现函数回调功能
可以用于界面之间的通信 同时可以进行传值
2:注意:定义Block必须使用copy修饰 retain和assign会照成野指针问题
3:不使用block时候需要销毁
-(void)dealloc{
//释放block
Block_release(_passValueBlock);
[super dealloc];
}
4:在block实现部分 不能直接使用实例变量,self调用属性,因为block会造成self引用计数加1,最终导致循环引用问题..
*传值(从second传到first)
block传值了类似代理传值
定义FirstView(根视图控制器)和ScondView
“SecondView.h”文件
#import <UIKit/UIKit.h>
typedef void(^PassValueBlock)(NSString *);
@interface SecondView : UIViewController
@property (nonatomic,retain)UITextField *textFild;
//1: 声明属性 在第一个界面去接收block语法块
@property (nonatomic,copy)PassValueBlock passValueBlock;
@end
"SecondView.m"文件
//视图将要消失的适时候
-(void)viewDidDisappear:(BOOL)animated{
[super viewDidDisappear:animated];
//2 ; 调用block 传入参数
self.passValueBlock(_textFild.text);
}
"FirstView.m"文件
-(void)nextAction:(UIBarButtonItem *)Bt{
SecondView *seconVC = [[SecondView alloc]init];
[self.navigationController pushViewController:seconVC animated:YES];
[seconVC release];
//使用属性接收block语法块
__block FirstView *firstVC = self;
seconVC.passValueBlock = ^ void (NSString *string){
//将传入的参数 给空间赋值
//不用self 用firstVC
//原因: 对应block内部在使用外部对象的时候 会对该对象持有一份所有权
//如果不想持有 使用__block修饰该对象
//在ARC情况下 使用__weak
firstVC.textFild.text = string;
};
}