2.10 Swift 3 常用的Set方法

在理解了Set最基本的操作之后僻孝,這一節(jié)中消略,我們來(lái)看一些更實(shí)際的Set用法,它當(dāng)然不僅僅是和Dictionary存儲(chǔ)值的形式不同這么簡(jiǎn)單章钾。其中第一個(gè)要提到的就是墙贱,作為表示一組值的無(wú)序集合,Set支持各種常用的代數(shù)運(yùn)算方法伍玖。

Set的代數(shù)運(yùn)算

為了介紹各種運(yùn)算方法嫩痰,先定義兩個(gè)Set

var setA: Set = [1, 2, 3, 4, 5, 6]
var setB: Set = [4, 5, 6, 7, 8, 9]

然后,我們就可以對(duì)setAsetB進(jìn)行下面的運(yùn)算:

// {5, 6, 4}
let interSectAB: Set = setA.intersection(setB)
// {9, 7, 2, 3, 1, 8}
let symmetricDiffAB: Set = setA.symmetricDifference(setB)
// {2, 4, 9, 5, 6, 7, 3, 1, 8}
let unionAB: Set = setA.union(setB)
// {2, 3, 1}
let aSubstractB: Set = setA.subtracting(setB)

而上面這些代碼的含義窍箍,我們可以用下面這張圖清楚的表現(xiàn)出來(lái):

Common set op

除此之外串纺,上面這些API還有一個(gè)“可修改Set自身”的版本,而命名方式椰棘,就是在這些API的名稱前面纺棺,加上form,例如:

setA.formIntersection(setB) // { 5, 6, 4 }

這樣邪狞,setA的值祷蝌,就被修改成了取交集之后的值。關(guān)于這些API的用法帆卓,大家也可以參考SetAlgebra protocol中的說(shuō)明巨朦。

把Set用作內(nèi)部支持類型

很多時(shí)候,除了把Set作為一個(gè)集合類型返回給用戶之外剑令,我們還可以把它作為函數(shù)的內(nèi)部支持類型來(lái)使用糊啡。例如,借助于Set不能包含重復(fù)元素的特性吁津,為任意一個(gè)序列類型去重棚蓄。

我們給Sequence添加下面的擴(kuò)展:

extension Sequence where Iterator.Element: Hashable {
    func unique() -> [Iterator.Element] {
        var result: Set<Iterator.Element> = []

        return filter {
            if result.contains($0) {
                return false
            }
            else {
                result.insert($0)
                return true
            }
        }
    }
}

在這個(gè)例子里,我們使用了Set不能包含重復(fù)元素的特性碍脏,用result保存了所有已經(jīng)篩選的元素梭依,如果遇到重復(fù)的元素,就跳過(guò)典尾,否則役拴,就把它添加到result里用于下一次篩選。這樣急黎,我們就可以直接使用unique來(lái)去重了:

[1, 1, 2, 2, 3, 3, 4, 4].unique() // [1, 2, 3, 4]

IndexSet和CharacterSet

在Swift標(biāo)準(zhǔn)庫(kù)里扎狱,Set是唯一一個(gè)支持SetAlgebra protocol的類型侧到。但是,在Foundation里淤击,卻還有兩個(gè)額外的類型:IndexSetCharacterSet匠抗。

其中,IndexSetSet<Int>是非常類似的污抬,例如:

let oneToSix: IndexSet = [1, 2, 3, 4, 5, 6]

但當(dāng)我們要表達(dá)一連串正整數(shù)時(shí)汞贸,尤其是這個(gè)整數(shù)范圍比較大的時(shí)候,使用IndexSet要比使用Set<Int>更經(jīng)濟(jì)一些印机,因?yàn)?code>Set<Int>會(huì)保存這個(gè)范圍里的每一個(gè)整數(shù)矢腻,而IndexSet則會(huì)使用類似1...6這樣的形式保存一個(gè)范圍。因此射赛,要表達(dá)的范圍越大多柑,使用IndexSet就會(huì)越經(jīng)濟(jì)。并且楣责,由于IndexSet也完全實(shí)現(xiàn)了SetAlgebraCollection這兩個(gè)protocol竣灌,因此,它的用法秆麸,和Set幾乎是相同的初嘹。

另一個(gè)類Set類型,就是CharacterSet沮趣,它主要表示某一類字符的集合屯烦,通常,我們用這個(gè)類型來(lái)判斷字符串中是否包含特定類型的字符房铭,例如:

// String
let hw = "Hello world!"

// CharacterSet
let numbers = CharacterSet(charactersIn: "123456789")
let letters = CharacterSet.letters

// Actions
hw.rangeOfCharacter(from: numbers) // nil
hw.rangeOfCharacter(from: letters) // 

在上面的代碼中可以看到驻龟,我們即可以自定義一個(gè)字符集合,也可以使用標(biāo)準(zhǔn)庫(kù)中預(yù)定義好的一些特定的集合缸匪。大家可以在CharacterSet官方文檔中迅脐,找到完整的類型定義。

定義好集合之后豪嗽,我們就可以使用rangeOfCharacter(from:)來(lái)判斷String對(duì)象是否包含特定的字符了。如果包含豌骏,rangeOfCharacter會(huì)返回一個(gè)Range對(duì)象龟梦,否則,就返回nil窃躲。

What's next?

以上计贰,就是Set類型常用的一些操作和概念。至此蒂窒,關(guān)于Swift標(biāo)準(zhǔn)庫(kù)中和unordered collection相關(guān)的內(nèi)容躁倒,就告一段落了荞怒。在下一節(jié)中,我們將討論一個(gè)集合類型與range操作符關(guān)系的問(wèn)題秧秉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末褐桌,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子象迎,更是在濱河造成了極大的恐慌荧嵌,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,110評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件砾淌,死亡現(xiàn)場(chǎng)離奇詭異啦撮,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)汪厨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門赃春,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人劫乱,你說(shuō)我怎么就攤上這事织中。” “怎么了要拂?”我有些...
    開(kāi)封第一講書人閱讀 165,474評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵抠璃,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我脱惰,道長(zhǎng)搏嗡,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,881評(píng)論 1 295
  • 正文 為了忘掉前任拉一,我火速辦了婚禮采盒,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蔚润。我一直安慰自己磅氨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布嫡纠。 她就那樣靜靜地躺著烦租,像睡著了一般。 火紅的嫁衣襯著肌膚如雪除盏。 梳的紋絲不亂的頭發(fā)上叉橱,一...
    開(kāi)封第一講書人閱讀 51,698評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音者蠕,去河邊找鬼窃祝。 笑死,一個(gè)胖子當(dāng)著我的面吹牛踱侣,可吹牛的內(nèi)容都是我干的粪小。 我是一名探鬼主播大磺,決...
    沈念sama閱讀 40,418評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼探膊!你這毒婦竟也來(lái)了杠愧?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,332評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤突想,失蹤者是張志新(化名)和其女友劉穎殴蹄,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體猾担,經(jīng)...
    沈念sama閱讀 45,796評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡袭灯,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了绑嘹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片稽荧。...
    茶點(diǎn)故事閱讀 40,110評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖工腋,靈堂內(nèi)的尸體忽然破棺而出姨丈,到底是詐尸還是另有隱情,我是刑警寧澤擅腰,帶...
    沈念sama閱讀 35,792評(píng)論 5 346
  • 正文 年R本政府宣布蟋恬,位于F島的核電站,受9級(jí)特大地震影響趁冈,放射性物質(zhì)發(fā)生泄漏歼争。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評(píng)論 3 331
  • 文/蒙蒙 一渗勘、第九天 我趴在偏房一處隱蔽的房頂上張望沐绒。 院中可真熱鬧,春花似錦旺坠、人聲如沸乔遮。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,003評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蹋肮。三九已至,卻和暖如春璧疗,著一層夾襖步出監(jiān)牢的瞬間括尸,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,130評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工病毡, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人屁柏。 一個(gè)月前我還...
    沈念sama閱讀 48,348評(píng)論 3 373
  • 正文 我出身青樓啦膜,卻偏偏與公主長(zhǎng)得像有送,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子僧家,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • set 除了Dictionary之外雀摘,Set是Swift標(biāo)準(zhǔn)庫(kù)中,另一個(gè)主要的無(wú)序集合類型八拱,包含一組不重復(fù)的值阵赠。可...
    Jesmine陽(yáng)閱讀 3,929評(píng)論 0 0
  • 這是16年5月份編輯的一份比較雜亂適合自己觀看的學(xué)習(xí)記錄文檔肌稻,今天18年5月份再次想寫文章清蚀,發(fā)現(xiàn)簡(jiǎn)書還為我保存起的...
    Jenaral閱讀 2,762評(píng)論 2 9
  • 初見(jiàn)swift 打印‘hello world' print("hello world"); 教程 類型 基礎(chǔ)類型:...
    PanPan1127閱讀 854評(píng)論 0 2
  • 基礎(chǔ)部分(The Basics) 當(dāng)推斷浮點(diǎn)數(shù)的類型時(shí),Swift 總是會(huì)選擇Double而不是Float爹谭。 結(jié)合...
    gamper閱讀 1,293評(píng)論 0 7
  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis 枷邪? MyBatis 是支持定制化 SQL、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的...
    笨鳥(niǎo)慢飛閱讀 5,523評(píng)論 0 4