6.4 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	title, localeTitle
| title | localeTitle | 
|---|---|
| Clojure Hashmaps | Clojure Hashmaps | 
Хешмап - это коллекция, которая отображает ключи к значениям. У них разные имена на других языках; Python относится к ним как словарям, а объекты Javascript по существу работают как хэшмапы.
Хешмап может, как и многие коллекции, быть построен двумя способами. Существует функция-конструктор:
;; Note that each argument is *prepended* to the hashmap, not appended. 
 (def a-hashmap (hash-map :a 1 :b 2 :c 3)) 
 a-hashmap 
 ; => {:c 3, :b 2, :a 1} 
Вы также можете определить их, используя литерал hashmap. Это часто более кратким и ясным. Рекомендуется использовать запятые для разделения пар ключ / значение в хэшмапах, так как это может сделать границы более четкими.
;; This hashmap is actually in the right order, unlike the one above. 
 (def another-hashmap {:a 1, :b 2, :c 3}) 
 another-hashmap 
 ; => {:a 1, :b 2, :c 3} 
Ключевые слова и извлечение значений из хэшмапов
Задержать. Что это? :a ? :b ? :c ? Они выглядят странно. Вы видите, это ключевые слова. Их называют ключевыми словами, поскольку они часто используются в качестве ключей в хэшмапах.
Почему они часто используются в качестве ключей? Ну, в отличие от строк, ключевые слова могут использоваться как функции для извлечения значений из хэш-карты; нет необходимости в get или nth !
(def string-hashmap {"a" 1, "b" 2, "c" 3}) 
 ("a" string-hashmap) 
 ; => ClassCastException java.lang.String cannot be cast to clojure.lang.IFn 
 
 (def keyword-hashmap {:a 1, :b 2, :c 3}) 
 (:a keyword-hashmap) 
 ; => 1 
 
 ;; You can also pass a keyword a default value in case it's not found, just like get. 
 (:not-in-the-hashmap keyword-hashmap "not found!") 
 ; => "not found!" 
Преобразование других коллекций в хэшмапы
Преобразование в hashmap является сложным. Чтобы продемонстрировать, давайте попробуем использовать его как vec или seq .
(hash-map [:a 1 :b 2 :c 3]) 
 ; => IllegalArgumentException No value supplied for key: [:a 1 :b 2 :c 3] 
Функция hash-map считает, что мы пытаемся создать hash-map с [:a 1 :b 2 :c 3] качестве одного из ключей. Посмотрите, что произойдет, если мы дадим ему правильное количество аргументов:
(hash-map [:a 1 :b 2 :c 3] "foo") 
 ; => {[:a 1 :b 2 :c 3] "foo"} 
Чтобы преобразовать последовательность в хэш-карту, вам нужно будет использовать и понимать apply . К счастью, это довольно просто: apply существу деструкции коллекции перед тем, как применить к ней функцию.
;; These two expressions are exactly the same. 
 (+ 1 2 3) 
 ; => 6 
 (apply + [1 2 3]) 
 ; => 6 
Вот как вы преобразовали вектор в hashmap:
(apply hash-map [:a 1 :b 2 :c 3]) 
 ; => {:c 3, :b 2, :a 1} 
 
 ;; This is the same as: 
 (hash-map :a 1 :b 2 :c 3) 
 ; => {:c 3, :b 2, :a 1} 
Обновить хэш-карту
Вы можете обновить значения внутри HashMap с помощью assoc . Это позволяет добавлять новые пары ключ / значение или изменять старые.
(def outdated-hashmap {:a 1, :b 2, :c 3}) 
 
 (def newer-hashmap (assoc outdated-hashmap :d 4)) 
 newer-hashmap 
 ; => {:a 1, :b 2, :c 3, :d 4} 
 
 (def newest-hashmap (assoc newer-hashmap :a 22)) 
 newest-hashmap 
 ; => {:a 22, :b 2, :c 3, :d 4} 
 
 ;; Note that outdated-hashmap has not been mutated by any of this. 
 ;; Assoc is pure and functional. 
 outdated-hashmap 
 ; => {:a 1, :b 2, :c 3} 
Когда использовать хэш-карту?
Хешмап полезен, когда вы хотите дать имена вашим переменным. Если вы когда-нибудь думаете о себе: «Что, если я использовал объект ...», прежде чем вы выйдете из него и поймете, что используете Clojure, попробуйте использовать hashmap.
Они также полезны, если вы хотите связать два разных значения друг с другом. Возьмем, к примеру, шифр ROT13: вы можете связать \A с \N , \B с \M и т. Д. (Это было бы долго и скучно писать на большинстве языков, но у Clojure есть некоторые функции, которые могут сгенерировать его для вас и сделать это весело! )
|  Предыдущая |
 Предыдущая |  Главная
 Главная  | следующий
 | следующий  |
 |
| Векторы | Содержание | Чтобы добавить |
