swift 笔记 (二十一) —— 高级运算符

高级运算符

位运算符

按位取反: ~

按位与运算:  &

按位或运算:  |

按位异或运算:  ^

按位左移运算: <<

按位右移动算: >>

溢出运算符

自从swift里面提供了所谓的类型安全之后。我们就不能再用一个 Int.max 进行+1操作了,这样会导致报错。所以swift又提供了一个让我们在知道这会溢出的前提下,继续+1的溢出运算符,这听上去也不错。

溢出加法 &+

溢出减法 &-

溢出乘法 &*

溢出除法 &/

溢出取余 &%

有趣的是,我们知道许多的语言中。假设一个数被0除的话,会产生错误。而在swift中,溢出除法 &/ 被0除的话,就不会产生错误。而是会得到0值:

var a = Int.max &/ 0    //不会报错,则是a被赋值为0

var b = Int.max   / 0    // 报错。由于/不能溢出操作

优先级

虽然文档上还是描写叙述了优先级,但我认为一个正常人类是不会使用这么不经常使用的规则去写一个让还有一个正常人类不那么easy看懂的表达式的,所以能够忽略掉这里的优先级介绍,直接使用()来表明优先级。

运算符重载

swift里依旧提供了运算符重载。。

。。。不提供才可笑。。

可是,中置,前置,后置运算符的定义居然不一样。。

中置: @infix

中置运算符还包含 == , != 等等

前置: @prefix

@prefix func +(num:Int)
-> Int{

return num + 5

}

var a = 3

println(+a)     //结果是8

后置: @postfix

与前置几乎相同,就不写了。

组合赋值运算符: @assignment

自己定义运算符

operator prefix +++ { }  //定义了一个前置运算符 +++, 注意定义运算符的keyword operator

@prefix @assignment func +++
(inout num:Int) {

num += 10

}

var a = 1

+++a

println(a)     //得到结果是11

自己定义中置运算符的结合性和优先级

operator表示定义一个新的运算符,infix表示是中置运算符,运算符写作 +-, associativity 表示结合性,与后面的left一起表示为左结合。 precedence表示优先级。与后面的数字一起表示优先级为140 (默认值为100)

写在最后:别把运算符玩坏了!!

!!

时间: 2024-12-20 03:14:00

swift 笔记 (二十一) —— 高级运算符的相关文章

马哥学习笔记二十一——LVS DR模型

kernel parameter: arp_ignore: 定义接收到ARP请求时的响应级别: 0:只要本地配置的有相应地址,就给予响应: 1:仅在请求的目标地址配置请求到达的接口上的时候,才给予响应: arp_announce:定义将自己地址向外通告时的通告级别: 0:将本地任何接口上的任何地址向外通告: 1:试图仅向目标网络通告与其网络匹配的地址: 2:仅向与本地接口上地址匹配的网络进行通告: curl命令选项: --cacert <file> CA证书 (SSL) --capath &l

swift 笔记 (二十) —— 泛型

泛型 泛型是为了解决在针对不同数据类型,而做了同一种功能的操作导致的每个类型我们都要写一份代码的问题. 有了泛型,我们可以只写一份逻辑代码,而适应于不同的数据类型. func swapInt(inout num1:Int, inout num2: Int) { var tmp = num1 num1 = num2 num2 = tmp } func swapDouble(inout num1: Double, inout num2:Double) { var tmp = num1 num1 =

《Programming in Lua 3》读书笔记(二十一)

日期:2014.8.1 PartⅣ The C API 25 An Overview of the C API Lua是一种嵌入式语言.这就意味着Lua不是单独存在的,而是可以通过一系列的标准库将lua的特性嵌入至其他应用模块中. Lua以Lua interpreter(lua的解释器?)来解决了其不是独立程序,我们直到现在却又能独立使用Lua的问题.这个解释器是一个小型的程序(不超过500行代码),使用lua的标准库来实现独立解释程序,这个程序将处理与用户的交互等操作交给lua的标准库,这些库

swift笔记(二) —— 运算符

基本运算符 Swift支持大部分的标准C语言的操作符,而且做了一些改进,以帮助开发人员少犯低级错误,比方: 本该使用==的时候,少写了个=, if x == y {-} 写成了 if x = y {-} 你就悲剧了 在使用 +,-,*,/ 的时候,得到的结果溢出了.你还是悲剧了.要做非常多检查保证不溢出才行 然而,在Swift中,我们再也不用操心这些问题了.编译器会帮我们搞定的 Swift还提供了两个C语言中没有的二元操作符 .. 和 - 接下来,我们就来看看Swift中的使用方法 术语(原文中

kvm虚拟化学习笔记(二十一)之KVM性能优化学习笔记

本学习笔记系列都是采用CentOS6.x操作系统,KVM虚拟机的管理也是采用virsh方式,网上的很多的文章都基于ubuntu高版本内核下,KVM的一些新的特性支持更好,本文只是记录了CentOS6.x系列操作系统下KVM优化的点,有很多都是默认支持开启了的,除了采用virtio方式的磁盘IO,与网络IO接口优化之外,其它真是无需太多优化. 1. CPU性能优化 (1) 服务器或宿主机主板BIOS中开启Intel Virtualization Technology(简称VT), 如果主板支持In

Android学习笔记二十一.使用ContentProvider实现数据共享(四).操作系统(联系人)的ContentProvider

Android系统本身提供了大量的ContentProvider,例如联系人信息.系统的多媒体信息等,我们开发的应用程序主要是通过ContentResolver来调用系统的ContentProvider提供的query().insert().update()和delete()方法来获取Android内部的数据. 一.如何使用ContentResolver操作系统ContentProvider暴露的内部数据? 1.调用Activity的getContentResolver()获取ContentRe

(转)【D3D11游戏编程】学习笔记二十一:Cube Mapping及其应用之一:天空盒的实现

(注:[D3D11游戏编程]学习笔记系列由CSDN作者BonChoix所写,转载请注明出处:http://blog.csdn.net/BonChoix,谢谢~) 这一节讨论有关纹理映射的进阶内容:Cube Mapping. 1. 简介 单从名字上,就大概可以看出点端倪了,翻译成中文为立方体映射,因此肯定跟立方体有关系.确实,Cube Mapping就是使用六张正方形的图片来进行纹理映射的.这六张图片分别对应了一个立方体中的六个面.由于这个立方体是轴对齐的,因此每个面可以用坐标系中的六个轴方向来惟

Linux学习笔记&lt;二十一&gt;——busybox制作小系统

制作流程: kernel->initrd(busybox)->rootfs(busybox) kernel:直接利用/boot/vmlinuz-`uname -r`内核镜像或手动编译生成 initrd:编译busybox,在busybox的基础上建立initrd rootfs:同样在busybox的基础上建立rootfs 一.为小系统上的新硬盘建立分区并挂载在宿主机的相应目录,以便创建修改文件. /dev/hda1    100M    boot分区    挂载在/mnt/boot /dev/

Java笔记二十一.深入解析I/O编程之节点流

深入解析I/O编程之节点流 转载请表明出处:http://blog.csdn.net/u012637501(嵌入式_小J的天空) 在上一节我们说到IO流主要分为两个大类:节点流类和过滤流类(也称包装类).程序用于直接操作目标设备所对应的类叫节点流类;为更加灵活方便地读写各种类型的数据,程序也可用通过一个间接流类去调用节点流类而这个简介流类即为过滤流类(也称为包装类). 总之,无论是节点流类还是过滤流类,它们都属于字节流或字符流其中的一种.下面我们介绍一下常见的节点流类有哪些. 字****节***