使用单链表实现LRU(Least Recently Used)淘汰缓存机制
需求:存在一个单链表,在单链表尾部的都是越早之前添加的元素。
- 当元素被访问到时,会添加进缓存(也就是这个单链表中)。
 - 如果这个元素在之前已经被缓存到了链表中,则将这个元素从原来的位置删除,用头插法放到链表的头部。
 - 如果这个元素不在链表中,则根据链表的容量进行判断
 
- 缓存容量未满时,直接用头插法,放到链表的头部
 - 缓存容量已满时,首先删除链表尾部的元素,再将元素进行插入到头部。
 
创建Node对象
package com.codezs.datastruct.mylinkedlist;
public class Node<T> {
    T data;
    Node<T> next;
    Node(Node<T> next) {
        this.next = next;
    }
    public Node(T data, Node<T> next) {
        this.data = data;
        this.next = next;
    }
    public T getData(){
        return data;
    }
    public Node<T> getNext(){
        return next;
    }
    public void setNext(Node<T> next){this.next = next;};
    
}
对单链表实现LRU淘汰缓存机制的实现
package com.codezs.datastruct.mylinkedlist;
public class MyLinkedList<T> {
    //默认链表容量
    private final static Integer DEFAULT_CAPACITY = 10;
    //头结点
    private Node head;
    //链表长度
    private Integer length;
    //链表容量
    private Integer capacity;
    public MyLinkedList() {
        this.capacity = DEFAULT_CAPACITY;
        this.head = new Node(null);
        this.length = 0;
    }
    public MyLinkedList(Integer capacity) {
        this.capacity = capacity;
        this.head = new Node(null);
        this.length = 0;
    }
    public Node getHead(){
        return head;
    }
    //添加新的元素
    public void add(T data){
        Node<T> preNode = findPreNode(data);
        if (preNode != null){
            remove(preNode);
            insertNode(data);
        } else {
            if (length >= this.capacity){
                deleteNodeAtEnd();
            }
            insertNode(data);
        }
    }
    //获取查找到元素的前一个节点
    private Node<T> findPreNode(T data){
        Node node = head;
        while(node.getNext() != null){
            if (data.equals(node.getNext().getData())){
                return node;
            }
            node = node.getNext();
        }
        return null;
    }
    //删除node结点下一个元素
    private void remove(Node preNode){
        Node node = preNode.getNext();
        preNode.setNext(node.getNext());
        node = null;
        length--;
    }
    //头插法
    private  void insertNode(T data){
        Node node = head.getNext();
        head.setNext(new Node(data,node));
        length++;
    }
    //删除链表中最后一个元素
    private void deleteNodeAtEnd(){
        Node node = head;
        if (node.getNext() == null) {
            return;
        }
        while (node.getNext().getNext() != null) {
            node = node.getNext();
        }
        Node nextNode = node.getNext();
        node.setNext(null);
        nextNode = null;
        length--;
    }
    public boolean isEmpty(){
        return length == 0;
    }
    public int size(){
        return length;
    }
}