首页
/
每日頭條
/
生活
/
swift總結
swift總結
更新时间:2025-09-16 10:04:22
  • 數組(Array)是有序數據的集
  • 集合(Set)是無序無重複數據的集
  • 字典(Dictionary)是無序的鍵值對的集

注:Swift 中的數組、集合和字典必須明确其中保存的鍵和值類型

數組(Array)

有序列表存儲同一類型的多個值,相同的值可以多次出現

語法:Array<Element> or [Element] (推薦使用)

創建一個空數組

var ary : [String] = [] print("ary = \(ary)") // 打印結果: ary = [] // 添加一個 “123” ary.append("123") print("ary = \(ary)") // 打印結果: ary = ["123"]

創建有默認數據的數組

var ary1 = Array(repeating: 1, count: 2) var ary2 = [1,1] // ary1 等價于 ary2 var ary3 = ary1 ary2 // ary3 = [1,1,1,1] ary3 被推斷為 [Int]

數組的使用

// 獲取數組長度 ary3.count // 判斷數組是否有數據(count 是否為 0) ary3.isEmpty // 在最後面添加數據 6 ary3.append(6) ary3 =[6] // 根據下标獲取數據 ary[下标] // 0 開始 ary3[4] // 根據下标更改數據 // 改前: [1, 1, 1, 1, 6, 6] ary3[1] = 10 // ary3 = [1, 10, 1, 1, 6, 6] // 替換部分 2到4 ary3[2...4] = [17,18,67,89,0] // ary3 = [1, 10, 17, 18, 67, 89, 0, 6] //在指定位置添加數據項 // insert(newElement, at: Int) ary3.insert(22, at: 2) // ary3 = [1, 10, 22, 17, 18, 67, 89, 0, 6] // 删除指定位置數據 ary3.remove(at: 4) // ary3 = [1, 10, 22, 17, 67, 89, 0, 6] // 删除全部 ary3.removeAll() // 删除最後一個 ary3.removeLast() // 删除第一個 ary3.removeFirst()

注:最大索引值一直是 count - 1,下标 > count - 1 會照成數組下标越界

遍曆數組

for item in ary3 { print(item) }

集合(Set)

無序無重複數據的集

語法:Set<Element>

創建一個空集合

var st = Set<String>() print("st = \(st) ") // 打印 st = [] // 添加一個 ‘123’ st.insert("123") // st = ["123"]

創建有默認數據的集合

var st1:Set<String> = ["123","456","qbc","yusx"]

集合的使用

// 獲取集合長度 st1.count // 判斷集合是否有數據(count 是否為 0) st1.isEmpty // 添加數據 "iosa" st1.insert("iosa") // 删除指定數據數據 st1.remove("123") // 删除全部 st1.removeAll(); //集合中是否包含 "iosa" st1.contains("iosa") // 集合轉數組 st1.sorted

遍曆數組

for item in st1 { print(item) }

多個集合操作

swift總結(Swift筆記-集合類型)1

  • intersection(_:) 根據兩個集合的交集創建一個新的集合。
  • symmetricDifference(_:) 根據兩個集合不相交的值創建一個新的集合。
  • union(_:) 根據兩個集合的所有值創建一個新的集合。
  • subtracting(_:) 根據不在另一個集合中的值創建一個新的集合。

swift總結(Swift筆記-集合類型)2

  • 運算符(==)來判斷兩個集合包含的值是否全部相同。
  • isSubset(of:) 方法來判斷一個集合中的所有值是否也被包含在另外一個集合中。
  • isSuperset(of:) 方法來判斷一個集合是否包含另一個集合中所有的值。
  • isStrictSubset(of:) 或者 isStrictSuperset(of:) 方法來判斷一個集合是否是另外一個集合的子集合或者父集合并且兩個集合并不相等。
  • isDisjoint(with:) 方法來判斷兩個集合是否不含有相同的值(是否沒有交集)。
字典(Dictionary)

無序的鍵值對的集

語法:Dictionary<Key, Value>

創建一個字典

var dic:[String:Int] = [:] print("dic = \(dic)") // 打印 dic = [:] // 添加 dic["name"] = 123 // dic = ["name": 123]

創建有默認數據的字典

//[key 1: value 1, key 2: value 2] var dic1: [String: String] = ["name": "小明", "sex": "男"]

字典的使用

// 獲取集合長度 dic1.count // 判斷集合是否有數據(count 是否為 0) dic1.isEmpty // 添加數據 dic1["age"] = "22" // 改 dic1["age"] = "32" dic1.updateValue("小明1", forKey: "name") // 删除指定數據數據 dic1["age"] = nil dic1.removeValue(forKey: "age") // 删除全部 dic1.removeAll()

字典遍曆

for (dic1K, dic1V) in dic1 { print("\(dic1K): \(dic1V)") } // key for dic1K in dic1.keys { print(dic1K) } // value for dic1V in dic1.values { print(dic1V) }

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
補充養老保險是什麼意思
補充養老保險是什麼意思
補充養老保險是什麼意思?補充養老保險是指在基本養老保險外,根據自身經濟實力,為企業職工履行繳納基本養老保險費義務後,專門為其設立的附加保險,接下來我們就來聊聊關于補充養老保險是什麼意思?以下内容大家不妨參考一二希望能幫到您!補充養老保險是什...
2025-09-16
栗子怎樣儲存放的時間長
栗子怎樣儲存放的時間長
栗子怎樣儲存放的時間長?通風晾幹:闆栗含有一定的水分,散熱不均勻,很容易導緻起黴變質,因此闆栗在通風處攤開,是比較簡單、易操作的貯存方法,今天小編就來說說關于栗子怎樣儲存放的時間長?下面更多詳細答案一起來看看吧!栗子怎樣儲存放的時間長通風晾...
2025-09-16
負數算不算整數
負數算不算整數
負數算不算整數?負數不屬于自然數也不屬于整數自然數是大于等于0的整數,今天小編就來說說關于負數算不算整數?下面更多詳細答案一起來看看吧!負數算不算整數負數不屬于自然數也不屬于整數。自然數是大于等于0的整數。整數(integer)就是像-3,...
2025-09-16
梅幹菜燒肉
梅幹菜燒肉
梅幹菜燒肉?帶皮五花肉,紹興梅幹菜,紹興黃酒,老姜,細鹽,江南醬油,高湯,味精,白砂糖,我來為大家講解一下關于梅幹菜燒肉?跟着小編一起來看一看吧!梅幹菜燒肉帶皮五花肉,紹興梅幹菜,紹興黃酒,老姜,細鹽,江南醬油,高湯,味精,白砂糖。帶皮五花...
2025-09-16
玉米如何長期存放
玉米如何長期存放
玉米如何長期存放?要想保存新鮮玉米的話,可以先按照正常的方法将玉米煮熟,可以留兩層外衣來保留更多的甜度,下面我們就來聊聊關于玉米如何長期存放?接下來我們就一起去了解一下吧!玉米如何長期存放要想保存新鮮玉米的話,可以先按照正常的方法将玉米煮熟...
2025-09-16
Copyright 2023-2025 - www.tftnews.com All Rights Reserved