Swift重载和自定义运算符

Swift重载和自定义运算符,第1张

概述最近一直边忙毕设边学Swift,终于看完了官方的教程(语言参考暂不打算看),在iBooks上做了一些笔记(看英文伤不起),感觉Swift是一门大杂烩类型的语言,我会记录一些我自认为以前遇到较少或者需要重点记忆的语法特性,在此作为分享,这次是运算符的重载,几乎每门语言都有,只是语法不一样罢了。 (2014-8-8更新至beta5语法) 运算符重载 在Swift的官方文档中运算符重载叫做运算符函数(O

最近一直边忙毕设边学Swift,终于看完了官方的教程(语言参考暂不打算看),在iBooks上做了一些笔记(看英文伤不起),感觉Swift是一门大杂烩类型的语言,我会记录一些我自认为以前遇到较少或者需要重点记忆的语法特性,在此作为分享,这次是运算符的重载,几乎每门语言都有,只是语法不一样罢了。
(2014-8-8更新至beta5语法)

运算符重载

在Swift的官方文档中运算符重载叫做运算符函数(Operator Functions),顾名思义就是对已经有的运算符覆盖定义自己的函数实现。三元运算符(a?b:c)和默认的默认的赋值符(=)是不可重载的。

中缀运算符的重载

func关键字前使用属性@infix来重载中缀运算符,函数名为想要重载的中缀运算符:

123456
struct Vector2D {  var x= 0.0,y0.0 } func+(left:Vector2Dright)->returnx.y} 

上面的代码是对结构体Vector2D之间双目运算符+的重载,下面可以直接使用+Vector2D进行 *** 作了:

4
letvector3.01.0 anotherVector2.04.0combinedVector // combinedVector 是一个新的Vector2D,值为 (5.0,5.0) 

除了对双目运算符的重载,还有对比较运算符的重载

==Bool&&!=!left 现在我们可以使用这两个运算符来判断两个Vector2D对象是否相等

twoThreeanotherTwoThreeifprintln("这两个向量是相等的."// prints "这两个向量是相等的." 
前缀和后缀运算符的重载

前缀和后缀一元运算符重载需要在将func关键字前用prefixpostfix修饰,比如:

3
prefix-vector- 这段代码为Vector2D类型提供了单目减运算,并且是前缀,也就是取负 *** 作。

5
positivenegative// negative 为 (-3.0,-4.0)alsoPositive// alsoPositive 为 (3.0,4.0) 
组合赋值运算符的重载

组合赋值是其他运算符和赋值运算符一起执行的运算。如+=把加运算和赋值运算组合成一个 *** 作。实现一个组合赋值符号需要把运算符的左参数设置成inout,因为这个参数会在运算符函数内直接修改它的值。

+=inoutright 因为加法运算在之前定义过了,这里无需重新定义。所以,加赋运算符函数使用已经存在的高级加法运算符函数来执行左值加右值的运算。

originalvectorToAdd// original 现在为 (4.0,6.0) 

你可以将赋值运算结合prefixpostfix修饰,例如实现一个Vector2D的前缀自增运算符(++a)。

@prefix++ 这个前缀使用了已经定义好的高级加赋运算,将自己加上一个值为(1.0,1.0)的对象然后赋给自己,然后再将自己返回。

toIncrementafterIncrement++// toIncrement 现在是 (4.0,5.0)// afterIncrement 现在也是 (4.0,5.0) 
自定义运算符

标准的运算符不够玩,那你可以声明一些个性的运算符,但个性的运算符只能使用这些字符/ = - + * % < > ! & | ^ . ~
新的运算符声明需在全局域使用operator关键字声明,可以声明为前缀,中缀或后缀的,分别用prefixinfixpostfix修饰。

1
operator+++{}

这段代码定义了一个新的前缀运算符叫+++,此前Swift并不存在这个运算符。此处为了演示,我们让+++Vector2D对象的 *** 作定义为“双自增”(prefix doubling incrementer) 这样一个独有的 *** 作,这个 *** 作使用了之前定义的加赋运算(+=)实现了自已加上自己然后返回的运算。

 +++运算的实现是把自己再加上自己

tobedoubledafterDoubling+++// tobedoubled 现在是 (2.0,8.0)// afterDoubling 现在也是 (2.0,8.0) 

此外还可以定义运算符的结合性(associativity)和优先级(precedence),结合性(associativity)的值可取的值有left,right和none。左结合运算符跟其他优先级相同的左结合运算符写在一起时,会跟左边的 *** 作数结合。同理,右结合运算符会跟右边的 *** 作数结合。而非结合运算符不能跟其他相同优先级的运算符写在一起。
结合性(associativity)的值默认为none,优先级(precedence)默认为100。

678
infix+-associativityprecedence140firstVectorsecondVectorplusMinusvector// plusMinusvector 此时的值为 (4.0,-2.0) 

FROM: http://bluereader.org/article/2690294

总结

以上是内存溢出为你收集整理的Swift重载和自定义运算符全部内容,希望文章能够帮你解决Swift重载和自定义运算符所遇到的程序开发问题。

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

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

原文地址: http://outofmemory.cn/web/1076723.html

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

发表评论

登录后才能评论

评论列表(0条)