Swift标准库中的协议_012_swift协议

//: Playground - noun: a place where people can play

import UIKit

//--Swift标准库中的协议---//

//1.实例的比较:判断两个实例值是否相同
let a = 4, b = 4
a == b //(Int类型的比较)

//自定义结构体类型,进行是否相等的比较
struct Games {

    var winCount : Int
    var loseCount : Int
}

let g1 = Games(winCount: 2, loseCount: 1)
let g2 = Games(winCount: 2, loseCount: 1)

//g1 == g2

//自定义类型判断是否相等需要遵守协议Equatable

extension Games : Equatable {}

//==为方法名,因为此协议方法是通过==来调用
func ==(g1 : Games, g2 : Games) -> Bool {

    return g1.winCount == g2.winCount && g1.loseCount == g2.loseCount

}

if g1 == g2 {
    print("相同")
} else {
    print("不同")
}

//2.比较两个实例的大小 Comparable
extension Games : Comparable {}

//协议方法实现的逻辑由编程者自己定义,要符合常规的逻辑
func <(g1 : Games, g2 : Games) -> Bool {

    let gScore1 = g1.winCount - g1.loseCount
    let gScore2 = g2.winCount - g2.loseCount

    return gScore1 < gScore2
}

g1 < g2

//3.哈希协议
class Student {

    var ID : Int?
    var name : String?

    init(ID: Int, name:String) {

        self.ID = ID
        self.name = name
    }
}

extension Student : Hashable {
    //扩展计算属性hashValue
    var hashValue : Int {

        return ID!

    }

}
//Hashable继承自Equatable协议,因此必须实现==协议方法
func ==(s1 : Student, s2 : Student) -> Bool {

    return s1.ID == s2.ID

}

var s1 = Student(ID: 1000, name: "kathy")
var s2 = Student(ID: 1001, name: "Tom")

let stuSet : Set<Student> = [s1, s2, s2, s2]
stuSet.count

let stuDic : [Student : String] = [s1 : "Class 1", s2 : "Class 2"]

stuDic.count
时间: 2024-12-27 07:54:42

Swift标准库中的协议_012_swift协议的相关文章

swift标准库中常见的55个协议。

swift标准库中常见的55个协议. 从协议名结尾字面上我们可以将Protocol分为able.Type.Convertible 三类 从功能角度上来讲的话可以总结为: 功能添加型(able结尾) "可以做什么?" 举例: Hashable: 给你的实例添加一个生成哈希值的功能. Equatable: 给你的实例添加一个判断相等的功能. 2.类型对比型(Type结尾) "这个实例是什么?" 举例: CollectionType: swift中所有的集合类型都要遵守的

STL笔记(6)标准库:标准库中的排序算法

STL笔记(6)标准库:标准库中的排序算法 标准库:标准库中的排序算法The Standard Librarian: Sorting in the Standard Library Matthew Austern http://www.cuj.com/experts/1908/austern.htm?topic=experts 用泛型算法进行排序    C++标准24章有一个小节叫“Sorting and related operations”.它包含了很多对已序区间进行的操作,和三个排序用泛型

c/c++标准库中的文件操作总结

1 stdio.h是c标准库中的标准输入输出库 2 在c++中调用的方法 直接调用即可,但是最好在函数名前面加上::,以示区分类的内部函数和c标准库函数. 3 c标准输入输出库的使用 3.1 核心结构体 FILE结构体 打开一个文件的时候获取它,然后就可以不用管它了. 3.2 核心方法 3.2.1 fopen 第一个字符串是文件的路径. 第二个参数是一个字符串,表示操作该文件的模式,"rb"表示read binary,即以二进制的形式来读该文件. 3.2.2 fseek 第一个参数是F

参考C++STL标准库中对了的使用方法

http://www.cppblog.com/zhenglinbo/archive/2012/09/18/191170.html 参考:http://www.cppblog.com/zhenglinbo/archive/2012/09/18/191170.html 当然是使用c++中的STL 的queue啦.下面简要介绍一下使用方法. 1 准备工作 头文件 #include<queue> 2 声明和定义的方法.STL的队列是泛型模板,支持任何内置和构造类型. 比如对于刚才那个牛奶问题.我把状态

C++标准库中next_permutation和pre_permutation实现原理

标准库中next_permutation函数:找当前序列中元素排列的下一个排列,按照字典顺序进行排列.比如说数组排列"123",那么它的下一个排列为"132",并且返回true.如果当前序列没有下一个排列,我们返回false,且把当前排列置为最小的排列,比如说:排列"321",因为该排列已经是最大的排列,所以它没有下一个排列.我们把该排列置为"123",并且返回false. 标准库实现两个重载版本的next_permutati

Swift中如何化简标准库中冗长的类实例初始化代码

可能有些童鞋并不知道,在Swift中缩写点符号对于任何类型的任何static成员都有效. 我们实际写一个例子看一下: import UIKit class CFoo{ static let sharedInstance = CFoo() } struct SFoo{ static let sharedInstance = SFoo() } let foo:CFoo = .sharedInstance let f:SFoo = .sharedInstance 以上代码中可以看到,foo类型为CFo

linux下Qt调用非标准库中的函数调用----------如pthread_create、pthread_cond_***、、

在Linux下Qt中使用POSIX标准的pthread_creaet函数调用创建新线程,使用如下代码后编译通过 extern "C" { #include <pthread.h> } 但是运行后发现并未成功创建新线程,并且无报错!!! (编译链接时有添加:-lpthread) 其中原因本人尚不清楚... 并且pthread_mutex_*** (互斥锁).pthread_cond_*** (条件变量) 等相关函数估计也无效... 后来借鉴网友提供的方法:将C文件创建成函数库

《深入实践C++模板编程》之六——标准库中的容器

1.容器的基本要求 a.并非所有的数据都可以放进容器当中.各种容器模板对所存数据类型都有一个基本要求——可复制构造.将数据放进容器的过程就是通过数据的复制构造函数在容器内创建数据的一个副本的过程. b.容器中必须有若干与所存数据类型有关的嵌套定义类型. C::value_type 容器所存数据类型 C::reference 容器数据的引用类型 C::const_reference 容器数据的只读引用类型 C::size_type 容器容量类型,通常是一个无符号整数类型 c.除嵌套类型定义外,容器

C++11标准库中cstdio头文件新增的5个格式化I/O函数学习

刚开始学网络编程,稍微扩展书上的简单C/S程序时,发现以前太忽略标准I/O这一块,查官网发现C++11新增了几个格式化I/O函数. snprintf    将格式化输出写入到有大小限制的缓存中 vfscanf     从流中读取数据到可变参数列表中 vscanf      读取格式化数据到可变参数列表中 vsnprintf  从可变参数列表中写入数据到有大小限制的缓存中 vsscanf     从字符串中读取格式化数据到可变参数列表中 主要谈谈snprintf,后面4个都是辅助可变参数列表的.