Nested Types - The Swift Programming Language (Swift 5.6)

NOTE

열거형은 특정 클래스 또는 구조체의 기능을 지원하기위해 생성!.

유사하게 더 복잡한 타입의 컨텍스트 내에서 사용하기 위해 순수하게 유틸리티 클래스와 구조체를 정의하는 것이 편리할 수 있다.!

Swift는 중첩된 타입(Nested Types)을 정의할 수 있으며 지원하는 타입의 정의 내에서 지원하는 열거형, 클래스,구조체를 중첩할 수 있다.!

다른 타입 내에서 타입을 중첩하려면 지원하는 타입의 외부 중괄호 내에서 정의를 작성. 타입은 필요한만큼의 수준으로 중첩될 수 있음.


중첩된 타입의 동작(Nested Types in Action)

struct BlackjackCard {
	
	// Nested Suit Enumeration
	enum Suit: Character {
		case spades = "♠", hearts = "♡", diamonds = "♢", clubs = "♣"
	}

	// Nested Rank Enumeration 
	enum Rank: Int {
		case two = 2, three, four, five, six, seven, eight, nine, ten
        case jack, queen, king, ace
        struct Values {
            let first: Int, second: Int?
        }
        var values: Values {
            switch self {
            case .ace:
                return Values(first: 1, second: 11)
            case .jack, .queen, .king:
                return Values(first: 10, second: nil)
            default:
                return Values(first: self.rawValue, second: nil)
            }
       }		
	}
	// BlackjackCard Properties and Methods
	let rank: Rank, suit: Suit
	var description: String {
		var output = "suit is \\(suit.rawValue),"
        output += " value is \\(rank.values.first)"
        if let second = rank.values.second {
            output += " or \\(second)"
        }
        return output
	}
}

<aside> 💡 Suit 열거형은 기호를 나타내는 원시 Character 값과 함께 4개의 일반적인 카드 모양

</aside>

<aside> 💡 Rank 열거형은 액면가를 나타내는 원시 Int값과 함께 가능한 13개의 카드 순위를 나타냄(이 원시 Int 값은 Jack, Queen, King, 그리고 Ace 카드에는 사용되지 않음)

</aside>

NOTE

Rank 열거형은 Values라는 자신의 중첩된 구조체를 더 정의. 대부분의 카드는 하나의 값을 가지지만 이 구조체에서는 에이스 카드는 2개의 값을 가지는 부분을 캡슐화함.