//理论
//闭包,类似oc中的block,其实它就是一段匿名函数,用于简化函数,
//闭包有三种类型:正常的,尾随闭包(闭包作为函数最后一个参数时), 还有一个叫逃逸闭包
//标准写法
// {(参数1:s1,参数2:s2) -> 返回值类型 in 代码 return:代码}
_ = ["aaa","bbb","ddd","cccc"];
// array.adda({(str1:String,str2:String) ->Bool in return str1 > str2});
//简化写法 swift有类型推断机制,所以可以省略参数类型和返回值
// array.adda({(str1,str2) in return str1>str2})
//在简化:函数题中之包含一行代码可以省略return关键字
// array.adda({(str1,str2) in str1 > str2})
//swift自动为内敛函数提供了参数名称简写功能 所以我们可以直接简化参数
//array.adda({$0>$1})
//尾随闭包
//尾随闭包:就是闭包作为函数的最后一个参数时:可以将该闭包写在参数所在的括号外面
// array.adda({(str1,str2) in str1 > str2})
//例子(里面是闭包也是最后一个参数)所以我们可以这样鞋
// array.adda(){
// return str1>str2
// }
//如果闭包是函数的唯一参数时我们可以把函数中的括号去掉
//array.adda{
//return str1>str2;
// }
//逃逸闭包
//我们上面写的都是非逃避闭包那么逃逸和非逃逸的区别是什么呢
//1.非逃逸闭包的生命周期很短闭包作为参数传递给他函数,函数执行,推出函数,非逃逸闭包生命周期结束
//逃逸闭包不是:当函数执行完毕以后逃逸闭包的引用仍然被其他对象应用.对于内存管理来说不是个好现象
//逃逸闭包用@escaping关键字修饰
// func someMethod(closur: @escaping ()->Void){
// //特别心动
// }
//逃逸闭包中self不能省略
//逃逸闭包的使用场景
//异步调用,存储