当前位置: 首页 > ai >正文

swift-14-可选项的本质、运算符重载、扩展

一、可选项的本质

1.1 可选项的本质是enum类型

public enum Optional<Wrapped> : ExpressibleByNilLiteral
case none
case some(Wrapped)
public init_ some: Wrapped)
}

1.2 平时写的可选项对应的原始写法

var age: Int? = 10
var age0: Optional<Int> = Optional<Int>.some(10)
var age1: Optional = .some(10)
var age2 = Optional.some(10)
var age3 = Optional(10)
age = nil
age3 = .nonevar age: Int? = nil
var age0 = Optional<Int>.none
var age1: Optional<Int> = .none可以混合写
var age: Int? = .none
age = 10
age = .some(20) age = nil

1.3 平时我们写的非枚举可选(本质就是枚举)和非可选类型支持switch 的写法

var age: int ? = 10
switch age {case let v?:
print("some", v) 
case nil:
print("none")
}
上面的写法等价于 
if let v = age
{
print("1", v)
}
else {
print ("2" )
}
var age: int = 10 switch age {
case let .some(v):
print("some", v)
case .none:
print("none")
}

1.4 多重可选项

var age_: Int? = 10
var age: Int?? = age_
age = nilvar age0 = Optional.some(Optional.some(10)) age0 = .none
var age1: Optional<Optional> = .some(.some(10)) age1 = .nonevar age: Int?? = 10
var age0: Optional<Optional> = 10

二、溢出运算符(Overflow Operator)

2.1 类型范围区间

print(Int8.min) // -128print(Int8.max) // 127print(UInt8.min) // 0
print(UInt8.max) // 255

2.2 那么溢出之后如何处理

Swift的算数运算符出现溢出时会抛出运行时错误

 Swift有溢出运算符( &+ &- &*),用来支持溢出运算

 假如范围是-128到127 之间,只用溢出运算符( &+ &- &*)后,数字依然会在-128到127这间进行变化,例如 当前数是a=127 使用了b=a&+ 1 ,那么b的值是-127,又回到最小的-127了


var min = UInt8.min 
print(min &- 1) // 255, Int8.maxvar max = UInt8.max
print(max &+ 1) // 0, Int8.min
print(max &* 2) // 254, 等价于  max &+ max

三、运算符重载( Operator Overload 

类、结构体、枚举可以为现有的运算符提供自定义的实现,这个操作叫做:运算符重载

注:重载的运算符一般放在对应的类、结构体、枚举内,写成static 的形式

struct Point {
var x: Int, y: Int
}func + (p1: Point, p2: Point) -> Point {
Point(x: p1.x + p2.x, y: p1.y + p2.y)
}let p = Point(x: 10, y: 20) + Point(x: 11, y: 22)
print(p) // Point(x: 21, y: 42)struct Point {
var x: Int, y: Int
static func + (p1: Point, p2: Point) -> Point {
Point(x: p1.x + p2.x, y: p1.y + p2.y)
}static func + (p1: Point, p2: Point) -> Point {
Point(x: p1.x + p2.x, y: p1.y + p2.y)
}
static func - (p1: Point, p2: Point) -> Point {
Point(x: p1.x - p2.x, y: p1.y - p2.y)
}
static prefix func - (p: Point) -> Point {
Point(x: -p.x, y: -p.y)
}
static func += (p1: inout Point, p2: Point) {
p1 = p1 + p2 }}static prefix func ++ (p: inout Point) -> Point {
p += Point(x: 1, y: 1)
return p
}
static postfix func ++ (p: inout Point) -> Point {
let tmp = p
p += Point(x: 1, y: 1) return tmp
}
static func == (p1: Point, p2: Point) -> Bool {
(p1.x == p2.x) && (p1.y == p2.y)
}

四、Equatable

要想得知2个实例是否等价,一般做法是遵守 Equatable 协议,重载 == 运算符

1、与此同时,等价于重载了  != 运算符

struct Point : Equatable { var x: Int, y: Int
}
var p1 = Point(x: 10, y: 20)
var p2 = Point(x: 11, y: 22)
print(p1 == p2) // false
print(p1 != p2) // true

注:有两种方式实现,第一种是遵守Equatable,第二种重载==运算符,但是一般情况下如果要比较2个实例是否等价,都需要遵守Equatable,因为如果我要定义一个比较方法带范型的参数的时候,范型参数需要制定具体的遵守的类型

4.2  Swift为以下类型提供默认的 Equatable 实现


1、没有关联类型的枚举

enum Answer {
case wrong case right
}
var s1 = Ayswer. wrong
var s2 = Answer.right
print (s1 == s2)


2、只拥有遵守 Equatable 协议关联类型的枚举(枚举遵守 Equatable不用实现Equatable定义的方法,但其他的必须实现Equatable定义的方法才行)


3、只拥有遵守 Equatable 协议存储属性的结构体
一下Point : Equatable 提供了默认的实现,Point遵守Equatable也不用再去实现Equatable定义的方法

struct Point : Equatable {
var x = 0, y = 0
}

4、如果是类的话,必须自己实现Equatable定义的额方法

5、引用类型比较存储的地址值是否相等(是否引用着同一个对象),使用恒等运算符 === !== 

http://www.xdnf.cn/news/14509.html

相关文章:

  • 【案例】性能优化在持续集成与持续交付中的应用
  • RPGMZ游戏引擎 如何手动控制文字显示速度
  • 传输层协议UDP/TCP
  • 【linux】bash脚本中括号问题
  • 巧用云平台API实现开源模型免费调用的实战教程
  • Linux嵌入式和单片机嵌入式的区别?
  • 数据库从零开始:MySQL 中的 DDL 库操作详解【Linux版】
  • excel 数据透视表介绍
  • 技术革新赋能楼宇自控:物联网云计算推动应用前景深度拓展
  • 【图像处理入门】11. 深度学习初探:从CNN到GAN的视觉智能之旅
  • Arduino入门教程:11、直流步进驱动
  • C#语言入门-task2 :C# 语言的基本语法结构
  • Oracle 中唯一索引对行锁的影响
  • 【支持向量机】SVM线性可分支持向量机学习算法——硬间隔最大化支持向量机及例题详解
  • 股票心理学习篇:交易的人性弱点 - 频繁交易
  • GNSS介绍
  • 基于React+Express的个人账单管理系统
  • 【Linux手册】进程优先级:操作系统世界里的“资源争夺”
  • Redis 的优势有哪些,它是CP 还是 AP?CAP 理论又是什么?
  • SpringBoot扩展——发送邮件!
  • 医疗低功耗智能AI网络搜索优化策略
  • 跨越网络界限,轻松实现广域网打印——HttpPrinter报表打印解决方案
  • Linux基本指令篇 —— mkdir指令
  • 苍穹外卖--WebSocket、来单提醒、客户催单
  • 【漏洞复现】Apache Kafka Connect 任意文件读取漏洞(CVE-2025-27817)
  • DeepSeek 助力 Vue3 开发:打造丝滑的日历(Calendar),日历_项目里程碑示例(CalendarView01_22)
  • 基于ARM SoC的半导体测试
  • windows,java后端开发常用软件的下载,使用配置
  • python校园拼团系统
  • A 股无风不起浪!金融吸血科技