Java를 사용하여 LRU 캐싱 알고리즘을 구현하는 방법
소개:
컴퓨터 과학 분야에서 캐싱은 데이터 읽기 및 쓰기 속도를 높이기 위해 일반적으로 사용되는 최적화 기술입니다. LRU(Least Recent Used)는 최근 데이터에 액세스한 시간을 기준으로 캐시에서 데이터를 제거할지 여부를 결정하는 일반적인 캐시 교체 전략입니다. 본 기사에서는 Java 언어를 사용하여 LRU 캐시 알고리즘을 구현하는 방법을 소개하고 자세한 코드 예제를 제공합니다.
먼저 이중 연결 목록 노드 클래스를 정의합니다.
class Node { int key; int value; Node prev; Node next; public Node(int key, int value) { this.key = key; this.value = value; } }
그런 다음 LRU 캐시 알고리즘을 구현하기 위해 LRUCache 클래스를 정의합니다.
import java.util.HashMap; class LRUCache { private int capacity; private HashMap<Integer, Node> map; private Node head; private Node tail; public LRUCache(int capacity) { this.capacity = capacity; this.map = new HashMap<>(); // 创建虚拟头节点和尾节点 this.head = new Node(0, 0); this.tail = new Node(0, 0); this.head.next = this.tail; this.tail.prev = this.head; } public int get(int key) { if (map.containsKey(key)) { Node node = map.get(key); removeNode(node); addToHead(node); return node.value; } return -1; } public void put(int key, int value) { if (map.containsKey(key)) { Node node = map.get(key); node.value = value; removeNode(node); addToHead(node); } else { if (map.size() == capacity) { map.remove(tail.prev.key); removeNode(tail.prev); } Node newNode = new Node(key, value); map.put(key, newNode); addToHead(newNode); } } private void removeNode(Node node) { node.prev.next = node.next; node.next.prev = node.prev; } private void addToHead(Node node) { node.prev = head; node.next = head.next; head.next.prev = node; head.next = node; } }
public class Main { public static void main(String[] args) { LRUCache cache = new LRUCache(2); cache.put(1, 1); cache.put(2, 2); System.out.println(cache.get(1)); // 输出 1 cache.put(3, 3); System.out.println(cache.get(2)); // 输出 -1 cache.put(4, 4); System.out.println(cache.get(1)); // 输出 -1 System.out.println(cache.get(3)); // 输出 3 System.out.println(cache.get(4)); // 输出 4 } }
결과 출력:
1
-1
-1
3
4
요약:
이 글에서는 Java 언어를 사용하여 LRU 캐시 알고리즘을 구현하는 방법을 소개합니다. 이중 연결 리스트와 해시 테이블 데이터 구조를 이용하여 LRU 캐시 알고리즘의 기본 기능을 구현할 수 있으며, 자세한 코드 예제를 제공합니다. 독자는 다양한 애플리케이션 시나리오를 충족하기 위해 실제 요구에 따라 수정하고 확장할 수 있습니다.
위 내용은 Java를 사용하여 LRU 캐싱 알고리즘을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!