创建: 2018/03/05

完成: 2018/03/05

更新: 2018/03/10 改变标题 [Swift4 模式] -> [Swift4 模式, 枚举型]

         补充RawRepresentable协议

【任务表】TODO

元组(taple)与switch
 

模式匹配(pattern matching): 检验构造和值是否一致的处理

 case来使用元组 

switch的待检验量可以是元组, 所有case列举的实例的型必须一致

switch location { // location: [Int, Int]
case (, ): // 具体值来匹配
...
case (..<, ...): // 匹配元素可以使用范围来判定
...
case (, _): //匹配元组第一个元素, 第二个无论是什么都成立
...
case (var a, ): // 需要获取时候直接声明var/let
...
default:
...
}

switch里用where

● 可以对case的元组附加条件

在:前面写

switch sample { // sample: Int
case :
...
case let a where a > : // where写在匹配标签和:之间
...
default:
...
}

● 可用逗号同时罗列多个条件

如果case里有var/let, 要保证声明的量的值一定会被决定

绝对可行的方法: 声明的量所有匹配量都带

switch sample { // sample: (Int, Int)
case (let a, 1), (10, 9) // 错误, (10, 9) 时a无法确定值
...
case (let a, ), (let a, ) where a == : // 可以, 所有标签都带a, a一定会被决定
...
case let (a, b) where a == b, let (a, b) where a == a*b: // 每一个标签都可以单独带where
...
default: ...
}
 switch里用可选型 
switch sample { // sample: (Int?, Int?) = (a, b)
case (?, ?): // a,b都存在且a = 1, b = 2
...
case ((..<)?, ?) // a, b都存在且a属性1..<9, b = 2
...
default:
...
}

● 带问号表示可能是nil, 非nil时进行下一步

1?   非nil且为1

nil   为nil

_?  非nil, 忽略值

   
   
枚举型

基本枚举型

共有型枚举型的一种 

enum 枚举型名 {
case 枚举型实例 // 多个也可以用,连接
case ...
   ...
}

例:

enum Sample1 {
case a
case b
case c
case d
} enum Sample2 {
case a, b, c, d
}

● 元素可以比较是否相等 ==, !=

 方法定义 

和其他方法定义一样

enum Sample2: CustomStringConvertible {
case a, b, c, d
func getNext() -> Sample2 {
switch self {
case .a:
return .b
case .b:
return .c
case .c:
return .d
case .d:
return .a
}
}
var description: String {
return "\(self.hashValue)"
}
}
let myEnumTest2: Sample2 = .a
print(myEnumTest2) //
print(myEnumTest2.getNext()) //
 值型枚举型 
enum 型名: 实体型 {
case 元素名 = 值 // 值可以不设定, 具体见下方默认值说明
...
}

● 所有成员都带同类型的值, 值必须各不相同

● 所带型叫实体型(raw type), 值为实体值(raw value)

● 实体型可为 各种Int, Float/Double, Bool, 字符串, 这些的组合

● 默认值:

  实体型为整数时, 默认第一个第一个为0, 不指定值的为前一个的值+1

             字符串时, 不指定则为元素名的字符串, String("元素名")

  其他型时必须制定值

● 获取实体值: rawValue

enum Sample3: Int {
case a=, b, c, d
}
let myEnumTest3: Sample3 = .d
print(myEnumTest3.rawValue) //

枚举型的构造函数

静态变量, 静态方法

只可定义计算型属性 var sample: Type { get {...} set {...} }

● 自带构造函数init?(rawValue:)

Sample.init(rawValue: )

● 自定义构造函数

self = 实例

init() {
self = Sample3.a
}

● 静态变量, 静态方法: 开头加 static

静态变量用作默认值,静态方法用来设定默认值等

   
   
共用型的枚举型
 共用型枚举型

enum 型名 {
case 元素名 元组定义 // 可以省略元组定义, 即最简单的枚举型
...
}

enum Sample4 {
case a (String, String)
case b (Int)
case c (first: Int, second: String) // 可以带标签
case d
}

生成实例

let myEnumTest4 = Sample4.a("", "")

元素不能互相比较

要比较则自己去采用Equalable

● 用在switch里时, 可用下两种方法获取值, 两种方法作用相同

case let Sample4.a(str1, str2)

case Sample4.a(let str1, let str2)

● 元组可带标签, switch的case里面可以省略标签

let/var 和标签连用时, 写法注意

case let .(first: a, second: b)

case .(first let a, second let b)
 if-case

不带元组的枚举型(简单枚举型), 值型枚举型可以比较

共用型枚举型的比较只能用switch, 除非自己采用Equalable

 比较方法

if case模式 = 式, ... { // ,... 相当于where部分
...
}

if case .a = p {
...
} if case let .a(x, y) = p {
...
} if case .t(, let y)? = p { // p不是nil, p.x=10
...
}

● , ...可以写模式匹配, 条件句, 可选绑定等

 for-in中使用case

case也可以用在for-in

for case let (a?, ?) in array { // array: [(Int?, Int?)]
print("a = \(a)")
}

● 和普通for-in一样迭代, 只有满足case才会执行代码块

 采用协议

可以采用协议

● 值型枚举型

自动采用RawRepresentable, 带有rawValue, init?(rawValue:)

protocol RawRepresentable {
associatedtype RawValue
init?(rawValue: Self.RawValue)
public var rawValue: Self.RawValue { get }
}
enum 型: 实体型, 协议1, 协议2,  ... {
...
}

● 共用型枚举型

enum 型: 协议1, 协议2, ... {
...
}
 改写自身元组内容的方法(method)

mutating func sample(x: Int) -> Bool {
switch self {
case let .(, a, b)
     self = .d // 把自己self完全替换为新元素
return a > x
...
}
 递归的构造体

● 在需要递归的case前加上indirect

enum Sample5 {
indirect case ...:
...
...
}

● 比较多时可以在enum前加上indirect

indirect enum Sample5 {
case ...:
...
...
}
 可选型与枚举型

可选型由共用型枚举型定义

public enum Optional<Wrapped> : ExpressibleByNilLiteral {
case none
case some(Wrapped)
public init(_ some: Wrapped)
...
}

以下两用法相同

var sample: Int? = 

if case let x? = sample { ... } // 不同于if-let: if let x = sample { ... }
if case let .some(x) = sample { ... }
   
   
   
模式匹配(pattern matching)
 模式匹配的规则

略  # TODO: Supply [模式匹配的规则 p186]

 模式匹配运算符

模式 ~= 受体

● 不需要case

   
   
   
   
   
   
   
   

Swift4 模式, 枚举型的更多相关文章

  1. 枚举型Enum和结构型Stuct

    枚举型实质就是使用符号来表示的一组相互关联的数据. Season currentSeason,nextSeason; currentSeason = Season.Spring; nextSeason ...

  2. 备忘录模式 Memento 快照模式 标记Token模式 行为型 设计模式(二十二)

    备忘录模式 Memento   沿着脚印,走过你来时的路,回到原点.     苦海翻起爱恨   在世间难逃避命运   相亲竟不可接近   或我应该相信是缘份   一首<一生所爱>触动了多少 ...

  3. FactoryMethod工厂方法模式(创建型模式)

    1.工厂方法模式解决的问题 现在有一个抽象的游戏设施建造系统,负责构建一个现代风格和古典风格的房屋和道路. 前提:抽象变化较慢,实现变化较快(不稳定) 整个抽象的游戏设施建造系统相对变化较慢,本例中只 ...

  4. Prototype原型模式(创建型模式)

    1.原型模式解决的问题 现在有一个抽象的游戏设施建造系统,负责构建一个现代风格和古典风格的房屋和道路. 前提:抽象变化较慢,实现变化较快(不稳定) 整个抽象的游戏设施建造系统相对变化较慢,本例中只有一 ...

  5. java中枚举型的定义以及使用

    1.如何定义枚举型 public enum gender{ GEN1("男","1"), GEN2("女","0"); ...

  6. 枚举型变量 ErrorStatus HSEStartUpStatus及使用

    ErrorStatus和C语言中的int .char一样,后面定义的HSEStartUpStatus是这个变量.举例,你的ErrorStatus 代表bool类型的0或者1. typedef enum ...

  7. MySQL进阶12-- 数据类型介绍: 数值型/字符型/日期型-- 正负溢出保护/枚举型/set型/时间戳

    /*进阶12 SQL 数据类型介绍 数值型: 整数: Tinyint(1b) < mediumint(3b)<smallint(2b) <int(4b) <bigint(8b) ...

  8. 工厂方法模式——创建型模式02

    1. 简单工厂模式     在介绍工厂方法模式之前,先介绍一下简单工厂模式.虽然简单工厂模式不属于GoF 23种设计模式,但通常将它作为学习其他工厂模式的入门,并且在实际开发中使用的也较为频繁. (1 ...

  9. Java 正则表达式匹配模式[贪婪型、勉强型、占有型]

    Greediness(贪婪型):最大匹配 X?.X*.X+.X{n,} 是最大匹配.例如你要用 “<.+>” 去匹配 “a<tr>aava </tr>abb”,也许 ...

随机推荐

  1. gcc,gdb基础学习1

    gcc: (1)gcc -O1 -S code.c   这里的-S可以的到code.c的汇编(只进行了预处理和编译这:两个阶段形成 了汇编代码code·s) (2)gcc -c code.c   这里 ...

  2. ibatis中的xml配置文件

    <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE sqlMap PUBLIC "-/ ...

  3. POJ 1741 Tree【树分治】

    第一次接触树分治,看了论文又照挑战上抄的代码,也就理解到这个层次了.. 以后做题中再慢慢体会学习. 题目链接: http://poj.org/problem?id=1741 题意: 给定树和树边的权重 ...

  4. loj517 计算几何瞎暴力(Trie树)

    题目: https://loj.ac/problem/517 分析: 操作4比较特殊,我们先来分析下操作4 操作4相当于需要一个数据结构,使得里面的数据有序(这有很多选择) 结合操作1,操作4的“排序 ...

  5. Java反射常用示例

    package xmq.study.reflection; import java.lang.annotation.Annotation; import java.lang.reflect.Const ...

  6. 30分钟学会如何使用Shiro(转)

    本文转自http://www.cnblogs.com/learnhow/p/5694876.html 感谢作者 本篇内容大多总结自张开涛的<跟我学Shiro>原文地址:http://jin ...

  7. 【APUE】fork函数

    #include <unisth.h> pid_t fork(void) fork函数被调用一次,返回两次.子进程的返回值是0,父进程的返回值是子进程的进程id. fork函数调用一次却返 ...

  8. Zookeeper 3.4 官方文档翻译

    说明 个人英语水平非常一般,理解可能有偏差,假设有翻译不恰当之处,请看官指点. 1.简单介绍 分布式系统就像动物园.当中每台server就像一仅仅动物,Zookeeper就像动物园管理员,协调.服务于 ...

  9. MySQL基础笔记(二) 完整性约束

    我们知道,一种数据模型必须包含三个基本的部分: 构造机制(数据结构):主要描述数据的类型.内容.性质以及数据间的联系等. 运算机制(数据操作):主要描述在相应的数据结构上的操作类型和操作方式. 约束机 ...

  10. Android学习 多读官网,故意健康---手势

    官网地址 ttp://developer.android.com/training/gestures/detector.html: 一.能够直接覆盖Activity的onTouch方法 public ...