Można programowo skonstruowania tabeli mieszania w czasie odczytu:
(defvar *ht* #.(let ((ht (make-hash-table)))
(loop for (key . value) in
'((a . 1) (b . 2) (c . 3))
do (setf (gethash key ht) value))
ht))
(describe *ht*)
#.
służy do oceny czasu odczytu. Następnie kompilator zrzuci tablicę haszującą do pliku FASL.
ten może być następnie zestawiane:
Korzystanie SBCL:
* (compile-file "/tmp/test.lisp")
; compiling file "/private/tmp/test.lisp" (written 24 MAY 2012 10:08:49 PM):
; compiling (DEFVAR *HT* ...)
; compiling (DESCRIBE *HT*)
; /tmp/test.fasl written
; compilation finished in 0:00:00.360
#P"/private/tmp/test.fasl"
NIL
NIL
* (load *)
#<HASH-TABLE :TEST EQL :COUNT 3 {100299EA43}>
[hash-table]
Occupancy: 0.2
Rehash-threshold: 1.0
Rehash-size: 1.5
Size: 16
Synchronized: no
T
* *ht*
#<HASH-TABLE :TEST EQL :COUNT 3 {100299EA43}>
Tworzenie tabeli mieszania jako funkcję:
(defun create-hashtable (alist
&key (test 'eql)
&aux (ht (make-hash-table :test test)))
(loop for (key . value) in alist
do (setf (gethash key ht) value))
ht)
https://github.com/vseloved/rutils/ blob/master/core/readtable.lisp # L10 –
Pamiętaj, że np. http://www.aiai.ed.ac.uk/~jeff/lisp/cl-pitfalls ostrzega przed używaniem tabel hash jako wartości dla "defconstant" formularzy. – Hugh
Dziękuję wszystkim. Wydaje się, że tej podstawowej funkcji brakuje w standardzie i trzeba ją w jakiś sposób dodać. Zamiast wprowadzać nową składnię, naśladując Perla lub PHP, co sądzisz o pisaniu makra, które owija tablicę make-hash i dodaje opcję: treść początkowa, ta sama opcja obsługiwana w standardzie przez np. Make-tablicę? Myślę, że nie będzie to prawdopodobnie bardzo wydajne, ponieważ treść będzie określona przez alistę, która musi być przemierzana, ale jest co najmniej bardziej spójna ze składnią Lispa. –