Javaを使用してLRUキャッシュアルゴリズムを実装する方法
Java を使用して LRU キャッシュ アルゴリズムを実装する方法
はじめに:
コンピューター サイエンスの分野では、キャッシュはデータを改善するために一般的に使用される最適化テクノロジです。読み取りと書き込みの速度。 LRU (最も最近使用されていない) は、データが最近アクセスされた時刻に基づいてキャッシュからデータを削除するかどうかを決定する一般的なキャッシュ置換戦略です。この記事では、Java 言語を使用して LRU キャッシュ アルゴリズムを実装する方法を紹介し、詳細なコード例を示します。
- LRU キャッシュ アルゴリズムの原理
LRU キャッシュ アルゴリズムは、時間ベースのキャッシュ置換戦略です。キャッシュがいっぱいで、新しいデータを挿入する必要がある場合、LRU アルゴリズムは、最も最近使用されていないデータを置換用に選択します。 - LRU キャッシュ アルゴリズムを実装するためのデータ構造
LRU キャッシュ アルゴリズムを実装するには、二重リンク リストとハッシュ テーブルを使用する必要があります。二重リンクリストは、データのアクセス順序を維持するために使用され、最近アクセスされたデータがリンクリストの先頭にあり、最も長い間アクセスされていないデータがリンクリストの末尾にあります。ハッシュ テーブルは、リンク リスト内のデータの場所をすばやく見つけるために使用されます。 - LRU キャッシュ アルゴリズムを実装するコード例
次に、LRU キャッシュ アルゴリズムの簡単な Java コード例を示します。
まず、二重リンク リスト ノード クラスを定義します。
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; } }
- 使用例
LRUCacheクラスの使用例を以下に示します。
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 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Java の乱数ジェネレーターのガイド。ここでは、Java の関数について例を挙げて説明し、2 つの異なるジェネレーターについて例を挙げて説明します。

Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。
