Swift3.0 - 真的很简单
Swift3.0 - 数据类型
Swift3.0 - Array
Swift3.0 - 字典
Swift3.0 - 可选值
Swift3.0 - 集合
Swift3.0 - 流控制
Swift3.0 - 对象和类
Swift3.0 - 属性
Swift3.0 - 函数和闭包
Swift3.0 - 初始化和释放
Swift3.0 - 协议protocol
Swift3.0 - 类和结构体的区别
Swift3.0 - 枚举
Swift3.0 - 扩展
Swift3.0 - 下标
Swift3.0 - 泛型
Swift3.0 - 异常错误
Swift3.0 - 断言
Swift3.0 - 自动引用计数(strong,weak,unowned)
Swift3.0 - 检测API
Swift3.0 - 对象的标识
Swift3.0 - 注释
Swift3.0 - 元类型
Swift3.0 - 空间命名
Swift3.0 - 对象判等
Swift3.0 - 探究Self的用途
Swift3.0 - 类簇
Swift3.0 - 动态调用对象(实例)方法
Swift3.0 - 文本输出
Swift3.0 - 黑魔法swizzle
Swift3.0 - 镜像
Swift3.0 - 遇到的坑
- 给存在的类型增加扩展
a.我们演示一个简单的例子
先定义一个协议
protocol Custom {
var describe:String{get}
}
通过扩展的方式,让Int 实现协议
extension Int:Custom{
var describe:String{
return String(self)
}
}
- 高级用法
a.需求: 给Array 扩展一个属性,但是只能让元素为Int 时才能使用
思路:承接上文,我们给Int 遵守了一个协议Custom ,我们就借助这个来实现需求
extension Array where Element : Custom {
var lastValue: Element{
return self[count-1]
}
}
// 使用
let nums = [1,2,3,4,5]
print(nums.lastValue)
运行结果:
5
b.如果想要在定义协议的时候,不指定变量名称,在实现协议的时候,再去设定变量类型,应该怎么写?
定义一个协议
protocol Draw{
associatedtype CompatableType // 自定义定义一个变量名字
var name:CompatableType{get}
}
如何继承协议
class Person:Draw{
typealias CompatableType = String // 给自定义变量名指定变量,即实现
var name:String{
return "人"
}
}
当然由于Swift 有类型推断能力,可以像下面这样写
class Person:Draw{
var name:String{
return "人"
}
}
你不能干的事情
- 不能给对象扩展存储属性