Swift: Enum-2
Merhaba, daha önce Swift dilinde enum kullanımına giriş yapan bir yazı yayımlamıştım. Şimdi enum’lara biraz daha derinlemesine değinmek istiyorum.
Associated Values
Swift’te enum kullanırken her bir case için yanında tutabileceği ek bilgiler verebiliriz. Bu sayede kullanım alanlarında daha detaylı bir veri alışverişi sağlayabiliriz.
Öncelikle PaymentType adında bir enum yaratalım ve iki case’imiz olsun.
Her bir kart için gerekli olan detay bilgileri de associated value olarak geçiyoruz.
1 2 3 4 5 6 7 8 |
enum PaymentType { case card(cardNo: String, cvv: String) case account(iban: String) } |
Ardından Payment adında bir struct oluşturuyoruz ve içerisinde amount ve paymentType adında iki değişkenimiz oluyor.
1 2 3 4 5 6 7 8 |
struct Payment { let amount: Int let paymentType: PaymentType } |
Payment tipinde yarattığımız objelerimizin payment type değişkenine gereken detaylı bilgileri associated value olarak veriyoruz.
1 2 3 4 5 6 |
let payment = Payment(amount: 20, paymentType: .account(iban: "TR9002938291828938181")) let payment2 = Payment(amount: 30, paymentType: .card(cardNo: "3333 3333 3333 333", cvv: "234")) |
Son olarak payment’lardan bir array oluşturuyoruz. Ardından her bir payment için ödeme yönteminde yer alan kart ise kart numarasını veya hesap ise iban’ı yazdırıyoruz. Eğer birden fazla associated value’muz var ve bazılarını o blokta kullanmak istemiyorsak “_” ile onun tanımlanmasını istemediğimizi belirtiyoruz.
1 2 3 4 5 6 7 8 9 10 11 12 |
[payment, payment2].forEach { payment in switch payment.paymentType { case .account(let iban): print("IBAN: \(iban)") case .card(let cardNo, _): print("Card No: \(cardNo)") } } |
Elde ettiğimiz sonuç aşağıdaki gibi olacaktır.
Where Keyword’ü Kullanımı
Yukarıdaki gibi bir yazdırma işleminde, bir kriterimiz varsa ve yalnızca bunu karşılayan case’lerde yazdırma işlemi yapmak istiyorsak where keywordünden faydalanabiliriz.
Örnek senaryomuzda PaymentType enum’ına yeni bir associated value geçiyoruz ve isBlocked olarak isimlendiriyoruz. Bu değerimiz, Bool tipinde olup belirtilen kart veya hesabın blokeli olup olmadığını belirtecektir.
1 2 3 4 5 6 7 8 |
enum PaymentType { case card(cardNo: String, cvv: String, isBlocked: Bool) case account(iban: String, isBlocked: Bool) } |
Ardından kart ve hesap türünden blokeli ve blokesiz olmak üzere yeni Payment nesneleri oluşturalım.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
let payment = Payment(amount: 20, paymentType: .account(iban: "TR9002938291828938181", isBlocked: false)) let payment2 = Payment(amount: 30, paymentType: .card(cardNo: "3333 3333 3333 3333", cvv: "234", isBlocked: true)) let payment3 = Payment(amount: 20, paymentType: .account(iban: "TR9002938291828938181", isBlocked: true)) let payment4 = Payment(amount: 20, paymentType: .card(cardNo: "4444 4444 4444 4444", cvv: "123", isBlocked: false)) |
Şimdi IBAN veya kart numaralarını yazdırmak için tekrar bir array oluşturuyoruz. Bu kez bloke olup olmaması bizim için bir kriter olduğu için bu değeri de kullanmamız gerekiyor. Bu sebeple iban veya cardNo değişkenleri gibi isBlocked değişkenini de oluşturuyoruz.
Ardından ilgili case içerisindeki kod bloğu için where keywordü ile kriter belirtiyoruz.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
[payment, payment2, payment3, payment4].forEach { payment in switch payment.paymentType { case .account(let iban, let isBlocked) where !isBlocked: print("IBAN: \(iban)") case .card(let cardNo, _, let isBlocked) where !isBlocked: print("Card No: \(cardNo)") default: print("Blocked.") } } |
İşlemin sonucunda aşağıdaki gibi bir sonuç elde ediyoruz.