All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.benmanes.caffeine.cache.FDA Maven / Gradle / Ivy

// Copyright 2021 Ben Manes. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.github.benmanes.caffeine.cache;

import java.lang.invoke.MethodHandles;
import java.lang.invoke.VarHandle;
import java.lang.ref.ReferenceQueue;

/**
 * WARNING: GENERATED CODE
 *
 * 

A cache entry that provides the following features: * *

    *
  • ExpireAccess *
  • WeakKeys (inherited) *
  • SoftValues (inherited) *
* * @author [email protected] (Ben Manes) */ @SuppressWarnings({"unchecked", "PMD.UnusedFormalParameter", "MissingOverride", "NullAway"}) class FDA extends FD { protected static final VarHandle ACCESS_TIME; static { MethodHandles.Lookup lookup = MethodHandles.lookup(); try { ACCESS_TIME = lookup.findVarHandle(FDA.class, NodeFactory.ACCESS_TIME, long.class); } catch (ReflectiveOperationException e) { throw new ExceptionInInitializerError(e); } } volatile long accessTime; Node previousInAccessOrder; Node nextInAccessOrder; FDA() {} FDA( K key, ReferenceQueue keyReferenceQueue, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { super(key, keyReferenceQueue, value, valueReferenceQueue, weight, now); ACCESS_TIME.set(this, now); } FDA(Object keyReference, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { super(keyReference, value, valueReferenceQueue, weight, now); ACCESS_TIME.set(this, now); } public Node getPreviousInVariableOrder() { return previousInAccessOrder; } public void setPreviousInVariableOrder(Node previousInAccessOrder) { this.previousInAccessOrder = previousInAccessOrder; } public Node getNextInVariableOrder() { return nextInAccessOrder; } public void setNextInVariableOrder(Node nextInAccessOrder) { this.nextInAccessOrder = nextInAccessOrder; } public long getVariableTime() { return (long) ACCESS_TIME.get(this); } public void setVariableTime(long accessTime) { ACCESS_TIME.set(this, accessTime); } public boolean casVariableTime(long expect, long update) { return (accessTime == expect) && ACCESS_TIME.compareAndSet(this, expect, update); } public final long getAccessTime() { return (long) ACCESS_TIME.get(this); } public final void setAccessTime(long accessTime) { ACCESS_TIME.set(this, accessTime); } public final Node getPreviousInAccessOrder() { return previousInAccessOrder; } public final void setPreviousInAccessOrder(Node previousInAccessOrder) { this.previousInAccessOrder = previousInAccessOrder; } public final Node getNextInAccessOrder() { return nextInAccessOrder; } public final void setNextInAccessOrder(Node nextInAccessOrder) { this.nextInAccessOrder = nextInAccessOrder; } public Node newNode( K key, ReferenceQueue keyReferenceQueue, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { return new FDA<>(key, keyReferenceQueue, value, valueReferenceQueue, weight, now); } public Node newNode( Object keyReference, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { return new FDA<>(keyReference, value, valueReferenceQueue, weight, now); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy