LISP-해시 테이블

해시 테이블 데이터 구조는 key-and-value키의 해시 코드를 기반으로 구성된 쌍입니다. 컬렉션의 요소에 액세스하기 위해 키를 사용합니다.

해시 테이블은 키를 사용하여 요소에 액세스해야 할 때 사용되며 유용한 키 값을 식별 할 수 있습니다. 해시 테이블의 각 항목에는 키 / 값 쌍이 있습니다. 키는 컬렉션의 항목에 액세스하는 데 사용됩니다.

LISP에서 해시 테이블 생성

Common LISP에서 해시 테이블은 범용 컬렉션입니다. 임의의 개체를 키 또는 인덱스로 사용할 수 있습니다.

해시 테이블에 값을 저장할 때 키-값 쌍을 만들고 해당 키 아래에 저장합니다. 나중에 동일한 키를 사용하여 해시 테이블에서 값을 검색 할 수 있습니다. 키에 새 값을 저장할 수 있지만 각 키는 단일 값에 매핑됩니다.

LISP의 해시 테이블은 키를 비교할 수있는 방법 (eq, eql 또는 같음)에 따라 세 가지 유형으로 분류 할 수 있습니다. 해시 테이블이 LISP 객체에서 해시 된 경우 키는 eq 또는 eql과 비교됩니다. 해시 테이블이 트리 구조에 해시되면 equal을 사용하여 비교됩니다.

그만큼 make-hash-table함수는 해시 테이블을 만드는 데 사용됩니다. 이 함수의 구문은 다음과 같습니다.

make-hash-table &key :test :size :rehash-size :rehash-threshold

어디-

  • 그만큼 key 인수는 키를 제공합니다.

  • 그만큼 :test인수는 키 비교 방법을 결정합니다. 세 개의 값 # 'eq, #'eql 또는 # 'equal 중 하나 또는 세 기호 eq, eql 또는 같음 중 하나를 가져야합니다. 지정하지 않으면 eql이 가정됩니다.

  • 그만큼 :size인수는 해시 테이블의 초기 크기를 설정합니다. 0보다 큰 정수 여야합니다.

  • 그만큼 :rehash-size인수는 해시 테이블이 가득 찰 때 해시 테이블의 크기를 얼마나 늘릴 지 지정합니다. 추가 할 항목 수인 0보다 큰 정수이거나 이전 크기에 대한 새 크기의 비율 인 1보다 큰 부동 소수점 숫자 일 수 있습니다. 이 인수의 기본값은 구현에 따라 다릅니다.

  • 그만큼 :rehash-threshold인수는 해시 테이블이 커지기 전에 얼마나 꽉 찼는 지 지정합니다. 이것은 0보다 크고 : rehash-size보다 작은 정수 (이 경우 테이블이 커질 때마다 크기가 조정 됨)이거나 0과 1 사이의 부동 소수점 숫자 일 수 있습니다. 이에 대한 기본값 인수는 구현에 따라 다릅니다.

인수없이 make-hash-table 함수를 호출 할 수도 있습니다.

해시 테이블에서 항목 검색 및 항목 추가

그만큼 gethash함수는 키를 검색하여 해시 테이블에서 항목을 검색합니다. 키를 찾지 못하면 nil을 반환합니다.

다음과 같은 구문이 있습니다.

gethash key hash-table &optional default

어디서-

  • key : 관련 키입니다.

  • hash-table : 검색 할 해시 테이블입니다.

  • default : 항목을 찾을 수없는 경우 반환되는 값이며 지정되지 않은 경우 nil입니다.

그만큼 gethash 함수는 실제로 두 값을 리턴하는데, 두 번째는 항목이 발견되면 참인 술어 값이고 항목이 발견되지 않으면 거짓입니다.

해시 테이블에 항목을 추가하려면 다음을 사용할 수 있습니다. setf 기능과 함께 gethash 함수.

main.lisp라는 새 소스 코드 파일을 만들고 그 안에 다음 코드를 입력합니다.

(setq empList (make-hash-table)) 
(setf (gethash '001 empList) '(Charlie Brown))
(setf (gethash '002 empList) '(Freddie Seal)) 
(write (gethash '001 empList)) 
(terpri)
(write (gethash '002 empList))

코드를 실행하면 다음 결과가 반환됩니다.

(CHARLIE BROWN)
(FREDDIE SEAL)

항목 제거

그만큼 remhash함수는 해시 테이블의 특정 키에 대한 항목을 제거합니다. 항목이 있으면 true이고 없으면 false 인 술어입니다.

이 함수의 구문은 다음과 같습니다.

remhash key hash-table

main.lisp라는 새 소스 코드 파일을 만들고 그 안에 다음 코드를 입력합니다.

(setq empList (make-hash-table)) 
(setf (gethash '001 empList) '(Charlie Brown))
(setf (gethash '002 empList) '(Freddie Seal)) 
(setf (gethash '003 empList) '(Mark Mongoose)) 

(write (gethash '001 empList)) 
(terpri)
(write (gethash '002 empList)) 
(terpri)
(write (gethash '003 empList))  
(remhash '003 empList)
(terpri)
(write (gethash '003 empList))

코드를 실행하면 다음 결과가 반환됩니다.

(CHARLIE BROWN)
(FREDDIE SEAL)
(MARK MONGOOSE)
NIL

맵해시 함수

그만큼 maphash 함수를 사용하면 해시 테이블의 각 키-값 쌍에 지정된 함수를 적용 할 수 있습니다.

두 개의 인수 (함수와 해시 테이블)를 취하고 해시 테이블의 각 키 / 값 쌍에 대해 한 번씩 함수를 호출합니다.

main.lisp라는 새 소스 코드 파일을 만들고 그 안에 다음 코드를 입력합니다.

(setq empList (make-hash-table)) 
(setf (gethash '001 empList) '(Charlie Brown))
(setf (gethash '002 empList) '(Freddie Seal)) 
(setf (gethash '003 empList) '(Mark Mongoose)) 

(maphash #'(lambda (k v) (format t "~a => ~a~%" k v)) empList)

코드를 실행하면 다음 결과가 반환됩니다.

3 => (MARK MONGOOSE)
2 => (FREDDIE SEAL)
1 => (CHARLIE BROWN)