Swift4 扩张(Extenstion), 集合(Set)
创建: 2018/03/09
完成: 2018/03/10
更新: 2018/04/19 修改小标题 [扩张的定义与使用协议] -> [通过扩张来采用协议]
更新: 2018/09/18 标题里增加英文方面自己快速找到 [Swift4 扩张, 集合] -> [Swift4 扩张(Extenstion), 集合(Set)]
| 扩张的声明与定义 | |||||||||||||||||||||||||||||||||||||||||||||
| 扩张的概要 |
可以对类, 构造体(系统固有的数据类型都算), 枚举型, 协议进行扩张 extension 型名: 协议 { // 协议可省略, 顺序随意
● 可以增加以下新定义 (●) 计算型属性, 计算型和容纳型静态属性(类属性) 即除容纳型实例属性外的属性 (●) 实例方法, 静态方法(类犯法) (●) 构造函数 (●) 索引subscript (●) 嵌套型声明(嵌套型在扩张定义内部用) ● 不可增加计算型实例属性, 属性监听器({willset didset}) |
||||||||||||||||||||||||||||||||||||||||||||
| 系统固有型的扩张例 |
extension String {
|
||||||||||||||||||||||||||||||||||||||||||||
| 扩张的定义与构造函数 |
扩张与构造函数 ● 构造体: 扩张定义的构造函数不会使构造体的默认构造函数和全项目构造函数无效 ● 类 扩张只能定义简易构造函数(带convenience), 不能定义指定构造函数 不能定义析构函数 |
||||||||||||||||||||||||||||||||||||||||||||
| 扩张定义与继承的注意 |
● 扩张的东西都自带final 无法被子类重载 ● 不能用扩张去重载父类属性/方法 |
||||||||||||||||||||||||||||||||||||||||||||
| 通过扩张来采用协议 | |||||||||||||||||||||||||||||||||||||||||||||
| 使用扩张来采用协议 |
class ExtensionSampleClass { // 什么都没有的空类
}
● 同时采用多个时用,隔开 extension SampleDataType: Protocol1, Protocol2, ... { // 多个用,隔开
|
||||||||||||||||||||||||||||||||||||||||||||
| 型内已有一部分/全部不定义 |
型内已有要采用的协议的一部分或全部定义时, 扩张里只需要补充缺少的. 不能改写型定义里已存在的 //内部已有一部分或全部实现 |
||||||||||||||||||||||||||||||||||||||||||||
| 协议的扩张 | |||||||||||||||||||||||||||||||||||||||||||||
| 协议的扩张 |
● 可以写方法, 计算型属性, 索引subscript ● 不可以写协议里的那种声明, 和容纳型实例/静态变量 ● 主要只要协议里东西的实现, 做默认实现 ● 改写默认实现不需要override |
||||||||||||||||||||||||||||||||||||||||||||
| 标准库的协议已有的扩张 |
例 public protocol Equatable { // 可等协议
|
||||||||||||||||||||||||||||||||||||||||||||
| 协议扩张时对型附加条件 |
对协议扩张时才能附加条件 ● 可附加的条件: 附属型: 协议 表示附属型必须采用指定协议 附属型 == 型 附属型必须是指定的型(可以是typealias后的) protocol SampleProtocol { // 样本协议
|
||||||||||||||||||||||||||||||||||||||||||||
| 协议扩张的多重继承 |
● 同时采用多个协议时不能有重名属性或方法 ● 相当于其他语言的mixin, trait |
||||||||||||||||||||||||||||||||||||||||||||
| 集合与协议 | |||||||||||||||||||||||||||||||||||||||||||||
| 通过哈希值实现高速搜索 |
● 集合和数组类似, 但不能有重复 ● 集合用于不需要重复元素或者需要使用集合运算的情况 ● 采用Hashable协议 public protocol Hashable: Equatable { // 继承Equatable, 需要实现==
|
||||||||||||||||||||||||||||||||||||||||||||
| 集合的声明与初始化 |
声明 var s: Set<类型> 初始化, 用数组, 有重复元素自动清除多余的 let setSample: Set<String> = ["a", "a", "b"] 也可以用init Set<Int>.init() // [] |
||||||||||||||||||||||||||||||||||||||||||||
| 元素的获取 |
和数组, 哈希表, 字符串一样采用Collection(继承Sequence) 参照: 传送门 |
||||||||||||||||||||||||||||||||||||||||||||
| 集合运算 |
前提: 元素同型 ● 采用SetAlgebra(继承Equatable, ExpressibleByArrayLiteral) ● 主要构造函数
● 主要属性
● 主要方法 S: sequence, 集合, 数组, 范围等 T: Set<T>的T
|
||||||||||||||||||||||||||||||||||||||||||||
| OptionSet协议 |
OptionSet协议 protocol OptionSet: SetAlgebra, RawRepresentation {
RawRepresentable协议 protocol RawRepresentable {
OptionSet的扩张(一部分) extension OptionSet {
● 要想使用默认实现, 只需定义RawValue型为Int, UInt等 并放一个rawValue属性 ● 不带任何选项的实例推荐用[]来生成 ● 用法: 放置选项, 相当于C, ObjC的比特列放置选项 可以去查看是否包含某选项, 是否包含某些选项等 struct SampleOptionSet: OptionSet { // 例, 四个选项optionA, B, C, D
|
||||||||||||||||||||||||||||||||||||||||||||
Swift4 扩张(Extenstion), 集合(Set)的更多相关文章
- Redis底层探秘(四):整数集合及压缩列表
整数集合 整数集合(intset)是集合键的底层实现之一,当一个集合只包含 整数值元素,并且这个集合的元素数量不多时,Redis就会使用郑书记和作为集合键的底层实现. 整数集合的实现 整数集合是red ...
- Java集合---ArrayList的实现原理
目录: 一. ArrayList概述 二. ArrayList的实现 1) 私有属性 2) 构造方法 3) 元素存储 4) 元素读取 5) 元素删除 6) 调整数组容量 ...
- ArrayList集合的实现原理
一. ArrayList概述: ArrayList是基于数组实现的,是一个动态数组,其容量能自动增长,类似于C语言中的动态申请内存,动态增长内存. ArrayList不是线程安全的,只能用在单线程环境 ...
- 重新开始学习javase_集合_List
一,List之ArrayList(转:http://blog.csdn.net/zheng0518/article/details/42198205) 1. ArrayList概述: ArrayLis ...
- Java集合ArrayList源码解读
最近在回顾数据结构,想到JDK这样好的代码资源不利用有点可惜,这是第一篇,花了心思.篇幅有点长,希望想看的朋友认真看下去,提出宝贵的意见. :) 内部原理 ArrayList 的3个字段 priva ...
- ava集合---ArrayList的实现原理
一.ArrayList概述 ArrayList是基于数组实现的,是一个动态数组,其容量能自动增长,类似于C语言中的动态申请内存,动态增长内存 ArrayList不是线程安全的,只能用在单线程环境下,多 ...
- Java多线程 阻塞队列和并发集合
转载:大关的博客 Java多线程 阻塞队列和并发集合 本章主要探讨在多线程程序中与集合相关的内容.在多线程程序中,如果使用普通集合往往会造成数据错误,甚至造成程序崩溃.Java为多线程专门提供了特有的 ...
- Java集合:ArrayList的实现原理
Java集合---ArrayList的实现原理 目录: 一. ArrayList概述 二. ArrayList的实现 1) 私有属性 2) 构造方法 3) 元素存储 4) 元素读取 5) 元素删除 ...
- JDK源码学习之 集合实现类
一.HashMap (1) 简介:java1.8版本之前HashMap的结构图如下: 数组的每个元素都是一个单链表的头节点,链表是用来解决冲突的,如果不同的key映射到了数组的同一位置处,就将其放入单 ...
随机推荐
- AlertDialog自定义
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...
- $.post()用法例子
1:删除用户操作 $('.delete').click(function(){ var classid=$(this).parent().siblings().eq(0).children().val ...
- Java重写equals方法和hashCode方法
package com.ddy; public class User { private Integer id; private String name; private St ...
- why在重写equals时还必须重写hashcode方法
首先我们先来看下String类的源码:可以发现String是重写了Object类的equals方法的,并且也重写了hashcode方法 public boolean equals(Object anO ...
- oracle数据库 SQL语句、内置函数大全
1.数值函数 函数 返回值 样例 显示 CEIL(n) 大于或等于数值n的最小整数 SELECT CEIL(10.6) FROM TABLE_NAME; 11 FLOOR(n) 小于等于数 ...
- Java实现敏感词过滤代码
原文:http://www.open-open.com/code/view/1445762764148 import java.io.BufferedReader; import java.io.Fi ...
- 如何扩展ArcGIS中的元数据编辑器
http://www.esrichina-bj.cn/old../library/arcnews16/Metadata.htm http://www.esrichina-bj.cn/old../lib ...
- Linux中查看文件或者文件夹大小
df -l 查看磁盘空间大小命令 df -hl 查看磁盘剩余空间 df -h 查看每个根路径的分区大小 du -sh 当前文件夹下所有文件大小(包括子文件大小 du -sm [文件夹] 返回该 ...
- MySQL5.6 怎样优化慢查询的SQL语句 -- 慢日志介绍
近期有个开发团队抱怨我们平台包括的mysql cluster不行,总是报mysql的"heartbeat Error".分析了他们收集的日志.没有发现mysql cluster节点 ...
- hdu 5087 Revenge of LIS II ( LIS ,第二长子序列)
链接:hdu 5087 题意:求第二大的最长升序子序列 分析:这里的第二大指的是,全部的递增子序列的长度(包含相等的), 从大到小排序后.排在第二的长度 cid=546" style=&qu ...