http://blog.csdn.net/minggeqingchun/article/details/54615722
闭包(Closure)
闭包可以捕获和存储其所在上下文中任意常量和变量的引用
闭包表达式:
{
(parameters) -> returnType in
statements
}
闭包可以使用常量、变量、inout类型作为参数,不提供默认值;元祖也可以作为参数和返回值
全局和嵌套函数实际上也是特殊的闭包
(1)全局函数是一个有名字但不会捕获任何值的闭包
(3)闭包表达式是一个捕获上下文变量和常量的匿名闭包
//!!!闭包的函数体部分由关键字in引入,该关键字表示闭包的参数和返回值类型定义已经完成,闭包函数体即将开始
- /*
- *闭包(Closure)
- 自包含的函数代码块,可以在代码中被传递和调用
- 闭包可以捕获和存储其所在上下文中任意常量和变量的引用
- 闭包表达式:
- {
- (parameters)->returnTypein
- statements
- }
- 闭包可以使用常量、变量、inout类型作为参数,不提供默认值;元祖也可以作为参数和返回值
- 全局和嵌套函数实际上也是特殊的闭包
- (1)全局函数是一个有名字但不会捕获任何值的闭包
- (2)嵌套函数是一个有名字可以捕获其封闭函数域内值的闭包
- (3)闭包表达式是一个捕获上下文变量和常量的匿名闭包
- */@H_301_197@
- //!!!闭包的函数体部分由关键字in引入,该关键字表示闭包的参数和返回值类型定义已经完成,闭包函数体即将开始@H_301_197@
- //sorted函数@H_301_197@
- letnames@H_301_197@:Array<String>=["China"@H_301_197@,"Alex"@H_301_197@,"Ewa"@H_301_197@,"Draw"@H_301_197@,"Bob"@H_301_197@]
- leti=names.sorted@H_301_197@{
- (s1@H_301_197@,s2@H_301_197@)->Boolin
- return@H_301_197@s1@H_301_197@>s2@H_301_197@
- }
- print(i)
- //尾部闭包@H_301_197@
- funcsomeFunction(closure:()->()){
- //函数体部分@H_301_197@
- //以下是不使用尾随闭包进行函数调用@H_301_197@
- someFunction(closure:{
- //闭包主体部分@H_301_197@
- })
- //使用尾随闭包进行函数调用@H_301_197@
- someFunction(){
- letdigitNames=[
- 0@H_301_197@:"Zero"@H_301_197@,1@H_301_197@:"One"@H_301_197@,2@H_301_197@:"Two"@H_301_197@,3@H_301_197@:"Three"@H_301_197@,4@H_301_197@:"Four"@H_301_197@,
- 5@H_301_197@:"Five"@H_301_197@,6@H_301_197@:"Six"@H_301_197@,7@H_301_197@:"Seven"@H_301_197@,8@H_301_197@:"Eight"@H_301_197@,9@H_301_197@:"Nine"@H_301_197@
- ]
- letnumbers=[16@H_301_197@,58@H_301_197@,510@H_301_197@]
- funcprintOut()->Void{
- letstrings=numbers.map@H_301_197@{
- (number)->Stringin
- varnumber=number
- varoutput=""@H_301_197@
- while@H_301_197@number>0@H_301_197@{
- output=digitNames[number%10@H_301_197@]!+output
- number/=10@H_301_197@
- }
- return@H_301_197@output
- print(strings)
- printOut()
- *运算符重载
- 让已有的运算符可以对自定义的类和结构进行运算
- */@H_301_197@
- struct@H_301_197@Point{
- varx=0.0@H_301_197@,y=0.0@H_301_197@
- func+(left:Point,right:Point)->Point{
- return@H_301_197@Point(x:left.x@H_301_197@+right.x@H_301_197@,y:left.y@H_301_197@+right.y@H_301_197@)
- letp1@H_301_197@=Point(x:3.0@H_301_197@,y:1.0@H_301_197@)
- letp2@H_301_197@=Point(x:2.0@H_301_197@,y:4.0@H_301_197@)
- letp3@H_301_197@=p1@H_301_197@+p2@H_301_197@
- print("p1=\(p1),p2=\(p2),p3=\(p3)"@H_301_197@)
- //前置、后置运算符(prefix、postfix)@H_301_197@
- prefixfunc-(vector:Point)->Point{
- return@H_301_197@Point(x:-vector.x@H_301_197@,y:-vector.y@H_301_197@)
- letpost=Point(x:3.0@H_301_197@,108); list-style:decimal-leading-zero outside; color:inherit; line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important"> letnag=-post
- letalp=-nag
- print("post=\(post),nag=\(nag),alp=\(alp)"@H_301_197@)
- //组合赋值运算符@H_301_197@
- func+=(left:inoutPoint,right:Point){
- left=left+right
- varp5@H_301_197@=Point(x:1.0@H_301_197@,y:2.0@H_301_197@)
- letp6@H_301_197@=Point(x:3.0@H_301_197@,108); list-style:decimal-leading-zero outside; color:inherit; line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important"> p5@H_301_197@+=p6@H_301_197@
- print("p5=\(p5)"@H_301_197@)
- //自定义运算符@H_301_197@
- prefixoperator+++
- prefixfunc+++(vector:inoutPoint)->Point{
- vector+=vector
- return@H_301_197@vector
- varbeDou=Point(x:1.0@H_301_197@,108); list-style:decimal-leading-zero outside; color:inherit; line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important"> letafterDou=+++beDou
- print("beDou=\(beDou),afterDou=\(afterDou)"@H_301_197@)
- /*
- *泛型函数:作用于任何类型
- 泛型使用了占位类型名字(通常用字母T来表示)来代替实际类型名字(如:Int、String等),占位类型名没有提示T必须是什么类型,但是它提示两个参数必须是同一类型T,不管T是什么类型,每次调用所传入实际类型才能决定T所代表类型
- print("\n泛型函数"@H_301_197@)
- funcswapTwoValues<T>(a:inoutT,b:inoutT){//要求两参数类型值一致@H_301_197@
- letc=a
- a=b
- b=c
- varbeA="测试"@H_301_197@
- varbeB="test"@H_301_197@
- swapTwoValues(a:&beA,b:&beB)
- print("a=\(beA),b=\(beB)"@H_301_197@)
- //栈操作@H_301_197@
- print("\n栈操作"@H_301_197@)
- struct@H_301_197@Stack<T>{
- varitems=[T]()
- mutatingfuncpush(item:T){
- items.append@H_301_197@(item)
- mutatingfuncpop()->T{
- return@H_301_197@items.removeLast@H_301_197@()
- varstackString=Stack<String>()
- stackString.push@H_301_197@(item:"ni"@H_301_197@)
- stackString.push@H_301_197@(item:"wo"@H_301_197@)
- stackString.push@H_301_197@(item:"ta"@H_301_197@)
- print(stackString.items@H_301_197@)
- extensionStack{
- vartopItem@H_301_197@:T?{
- return@H_301_197@items.isEmpty@H_301_197@?nil@H_301_197@:items[items.count@H_301_197@-1@H_301_197@]
- if@H_301_197@lettopItem=stackString.topItem@H_301_197@{
- print("Thetopitemonthestackis\(topItem)"@H_301_197@)
- }