Swift 문법 정리 #6
출처: 애플 공식 Swift 레퍼런스
Set
Set은 중복을 허용하지 않고 순서도 없는 값의 집합이다. Set 자료형은 값을 저장할 때 해시값을 사용한다. 따라서 사용자가 만든 커스텀 자료형을 Set에 저장하고 싶다면 반드시 Swift 표준 라이브러리의 Hasahble Protocol을 확장해서 사용해야 한다. 그리고 이건 Set 뿐만 아니라, Dictionary 자료형의 Key에도 해당하는 내용이다.
Set의 사용법은 대체적으로 Array와 유사하다. 단, insert 메소드의 경우 Index가 존재하지 않는데, 이는 Set은 순서가 없는 집합이기 때문이다.
var letters = Set<Character>()
letters.insert("a")
letters = []
letters += ["b"] // Error!
원소를 삭제하는 remove 메소드의 경우 Array와 다소 차이가 있다. 아래 예시를 보자.
let removedGenre = favoriteGenres.remove("Rock") // removedGenre -> String?
Set에서 remove는 Optional 값을 반환한다. 이는 삭제하려고 하는 값이 Set에 존재하지 않을 수 있기 때문이다. 따라서 remove를 사용할 때에는 반드시 Optional 여부를 잘 확인 해주어야 한다.
특정 값의 존재 여부는 contains(_:) 메소드를 통해 확인할 수 있다.
if favoriteGenres.contains("Funk") {
print("I get up on the good foot.")
}
만약 Set에 있는 값들을 정렬할 필요가 있을 경우, sorted(by: ) 메소드를 통해 수행할 수 있다.
for genre in favoriteGenres.sorted(by: <) {
print(genre)
}
Set 연산 수행
사진 출처: 애플 Swift 공식 레퍼런스
위 사진은 Swift에서 제공하는 Set 연산의 종류들이다. 교집합, 합집합, 차집합 등의 연산들을 제공하고 있다.
let oddDigits: Set = [1, 3, 5, 7, 9]
let evenDigits: Set = [0, 2, 4, 6, 8]
let singleDigitPrimeNumbes: Set = [2, 3, 5, 7]
oddDigits.union(evenDigits).sorted()
// [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
oddDigits.intersection(evenDigits).sorted()
// []
oddDigits.subtracting(singleDigitPrimeNumbes).sorted()
// [1, 9]
oddDigits.symmetricDifference(singleDigitPrimeNumbes).sorted()
// [1, 2, 9]
그리고 아래와 같이 부분집합의 여부도 확인할 수 있다.
let houseAnimals: Set = ["Dog", "Cat"]
let farmAnimals: Set = ["Cow", "Chicken", "Sheep", "Dog", "Cat"]
let cityAnimals: Set = ["Pigeon", "Rat"]
houseAnimals.isSubset(of: farmAnimals) // true
farmAnimals.isSuperset(of: houseAnimals) // true
farmAnimals.isDisjoint(with: cityAnimals) // true
Author And Source
이 문제에 관하여(Swift 문법 정리 #6), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@rubinstory/Swift-문법-정리-6저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)