Objective-C中的block与Swift中的尾随闭包使用教程
前言
在项目开发中经常会去查iOS闭包怎么写,因为它的语法太古怪,两种语言写法不一,经常搞混,干脆记录下常用的写法算了
闭包定义
闭包是指可以包含自由(未绑定到特定对象)变量的代码块;这些变量不是在这个代码块内或者任何全局上下文中定义的,而是在定义代码块的环境中定义(局部变量)。“闭包”一词来源于以下两者的结合:要执行的代码块(由于自由变量被包含在代码块中,这些自由变量以及它们引用的对象没有被释放)和为自由变量提供绑定的计算环境(作用域)。
OC中的block与Swift中的尾随闭包都起到了将参数作为返回值的作用,也就是常说的回调。
1.block的使用
在OC中block主要分为三种,分别是
(1)_NSConcreteGlobalBlock全局静态,
(2)_NSConcreteStackBlock保存在栈中,出函数作用域就销毁,
(3)_NSConcreteMallocBlock保存在堆中,retainCount==0销毁。
而我们在使用block时大致分为以下几步:
//1.使用typedef定义一个block typedefvoid(^CallBack1)();//不带参数 typedefvoid(^CallBack2)(NSString*test);//带参数 //2.通过属性声明 @property(nonatomic,copy)CallBackcallBack; //3.通过函数方法声明 -(void)functionCallBack:(CallBack)callBack;
其实呢,如果写的比较熟练了,也可以连着一起定义:
@property(nonatomic,strong)void(^completed1)();//不带参数 @property(nonatomic,strong)void(^completed2)(NSString*test);//带参数 -(void)functionCallBack:(void(^)())completed1;//不带参数 -(void)functionCallBack:(void(^)(NSString*test))completed2;//带参数
2.尾随闭包的使用
在Swift中,闭包是一段自包含的函数代码块,可以在代码中使用和传递,相当于一个匿名函数。
那么尾随闭包就是这个函数的最后一个参数是一个闭包,所以规定这个闭包既可以写在函数的参数括号里面,也可以直接放在最后面来使用,就像重新给这个函数定义了一次一样。
并且,它的写法和block很相似:
//1.使用typealias定义 typealiasfunctionBlock1=()->()//不带参数 typealiasfunctionBlock2=(String)->()//带参数 //2.声明函数体 funcblockTest1(complete:(functionBlock1))->(){ complete() } funcblockTest2(complete:(functionBlock2))->(){ letre:String="Cookie" complete(re) } //3.使用函数 blockTest1{} blockTest2{(result)in print(result) }
同样的,如果写的比较熟练了,也可以连着一起定义:
//1.声明函数体 funcblockTest(complete:(_result:String)->())->(){ letre:String="Cookie" complete(re) } //2.使用函数 blockTest{(result)in print(result) }
除此之外,swift中的闭包还包括逃逸闭包,这个闭包在函数返回之后才被执行,我们称该闭包从函数中逃逸,多用来做函数回调,与Objective-C里的Block有异曲同工之妙。自动闭包,作为参数传递给函数时,可以将闭包定义为自动闭包(使用关键字@autoclosure),这样传递参数时,可以直接传递一段代码(或者一个变量、表达式),系统会自动将这段代码转化成闭包。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。