Swift3.0-闭包、运算符重载

Swift3.0-闭包、运算符重载,第1张

概述http://blog.csdn.net/minggeqingchun/article/details/54615722 闭包(Closure)   自包含的函数代码块,可以在代码中被传递和调用   闭包可以捕获和存储其所在上下文中任意常量和变量的引用   闭包表达式:     {           (parameters) -> returnType in             statem

http://blog.csdn.net/minggeqingchun/article/details/54615722

闭包(Closure

自包含的函数代码块,可以在代码中被传递和调用

闭包可以捕获和存储其所在上下文中任意常量和变量的引用

闭包表达式:

{

(parameters) -> returnType in

statements

}

闭包可以使用常量、变量、inout类型作为参数,不提供默认值;元祖也可以作为参数和返回值

全局和嵌套函数实际上也是特殊的闭包

1)全局函数是一个有名字但不会捕获任何值的闭包

2)嵌套函数是一个有名字可以捕获其封闭函数域内值的闭包

3)闭包表达式是一个捕获上下文变量和常量的匿名闭包

//!!!闭包的函数体部分由关键字in引入,该关键字表示闭包的参数和返回值类型定义已经完成,闭包函数体即将开始

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

以上是内存溢出为你收集整理的Swift3.0-闭包、运算符重载全部内容,希望文章能够帮你解决Swift3.0-闭包、运算符重载所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1065180.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-26
下一篇 2022-05-26

发表评论

登录后才能评论

评论列表(0条)

保存