Clojure - Yıkım
Destructuring Clojure içindeki bir işlevselliktir, bir vektör gibi bir veri yapısından değerlerin çıkarılmasına ve veri yapısını açık bir şekilde geçmek zorunda kalmadan bunları sembollere bağlamasına izin verir.
Yıkımın tam olarak ne anlama geldiğine ve nasıl gerçekleştiğine dair bir örneğe bakalım.
Misal
(ns clojure.examples.example
(:gen-class))
(defn Example []
(def my-vector [1 2 3 4])
(let [[a b c d] my-vector]
(println a b c d)))
(Example)
Yukarıdaki program aşağıdaki çıktıyı üretir.
Çıktı
1 2 3 4
Yukarıdaki örnekte, aşağıdaki noktalara dikkat edilmelidir -
Bir tamsayı vektörünü 1, 2, 3 ve 4 olarak tanımlıyoruz.
Daha sonra kullanıyoruz ‘let’ 4 değişkeni (a, b, c ve d) my-vector değişkenine doğrudan atamak için ifade.
Eğer koşarsak ‘println’ dört değişken üzerindeki ifadede, bunların sırasıyla vektördeki değerlere atanmış olduklarını görebiliriz.
Dolayısıyla, clojure, 'let' ifadesi kullanılarak atandığında dört değeri olan my-vector değişkenini yok etti. Yapısı bozulan dört değer daha sonra buna göre dört parametreye atandı.
Atanabilecekleri karşılık gelen bir değere sahip olmayan fazla değişkenler varsa, bunlara sıfır değeri atanacaktır. Aşağıdaki örnek bu noktayı netleştirir.
Misal
(ns clojure.examples.hello
(:gen-class))
(defn Example []
(def my-vector [1 2 3 4])
(let [[a b c d e] my-vector]
(println a b c d e)))
(Example)
Yukarıdaki program aşağıdaki çıktıyı üretir. Son değişken 'e' vektörde karşılık gelen bir değere sahip olmadığından, bunun sıfır olduğunu çıktıdan görebilirsiniz.
Çıktı
1 2 3 4 nil
geri kalan
'The-rest' değişkeni, herhangi bir değişkene atanamayan kalan değerleri saklamak için kullanılır.
Bunun nasıl kullanıldığına dair bir örnek aşağıdaki programda gösterilmektedir.
Misal
(ns clojure.examples.example
(:gen-class))
(defn Example []
(def my-vector [1 2 3 4])
(let [[a b & the-rest] my-vector]
(println a b the-rest)))
(Example)
Yukarıdaki program aşağıdaki çıktıyı üretir. Çıktıdan, 3 ve 4 değerlerinin herhangi bir değişkene atanamayacağını, bu nedenle 'geri kalan' değişkenine atandıklarını açıkça görebilirsiniz.
Çıktı
1 2 (3 4)
Haritaları Yıkmak
Vektörler gibi haritalar da imha edilebilir. Aşağıda bunun nasıl başarılabileceğine dair bir örnek verilmiştir.
Misal
(ns clojure.examples.example
(:gen-class))
(defn Example []
(def my-map {"a" 1 "b" 2})
(let [{a "a" b "b"} my-map]
(println a b)))
(Example)
Yukarıdaki program aşağıdaki çıktıyı üretir. Programdan, “a” ve “b” nin harita değerlerinin a ve b değişkenlerine atandığını açıkça görebilirsiniz.
Çıktı
1 2
Benzer şekilde, vektörler durumunda, yok etme gerçekleştiğinde haritada karşılık gelen bir değer yoksa, değişkene bir sıfır değeri atanacaktır.
Aşağıda bir örnek verilmiştir.
Misal
(ns clojure.examples.example
(:gen-class))
(defn Example []
(def my-map {"a" 1 "b" 2})
(let [{a "a" b "b" c "c"} my-map]
(println a b c)))
(Example)
Yukarıdaki program aşağıdaki çıktıyı üretir.
Çıktı
1 2 nil