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

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

// Copyright 2020 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 com.github.benmanes.caffeine.base.UnsafeAccess;
import java.lang.Object;
import java.lang.SuppressWarnings;
import java.lang.ref.ReferenceQueue;

/**
 * WARNING: GENERATED CODE
 *
 * A cache entry that provides the following features:
 * 
    *
  • ExpireWrite *
  • WeakKeys (inherited) *
  • StrongValues (inherited) *
  • ExpireAccess (inherited) *
* * @author [email protected] (Ben Manes) */ @SuppressWarnings({"unchecked", "PMD.UnusedFormalParameter", "MissingOverride", "NullAway"}) class FSAW extends FSA { protected static final long WRITE_TIME_OFFSET = UnsafeAccess.objectFieldOffset(FSAW.class, com.github.benmanes.caffeine.cache.LocalCacheFactory.WRITE_TIME); volatile long writeTime; Node previousInWriteOrder; Node nextInWriteOrder; FSAW() { } FSAW(K key, ReferenceQueue keyReferenceQueue, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { super(key, keyReferenceQueue, value, valueReferenceQueue, weight, now); UnsafeAccess.UNSAFE.putLong(this, WRITE_TIME_OFFSET, now); } FSAW(Object keyReference, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { super(keyReference, value, valueReferenceQueue, weight, now); UnsafeAccess.UNSAFE.putLong(this, WRITE_TIME_OFFSET, now); } public Node getPreviousInVariableOrder() { return previousInWriteOrder; } public void setPreviousInVariableOrder(Node previousInWriteOrder) { this.previousInWriteOrder = previousInWriteOrder; } public Node getNextInVariableOrder() { return nextInWriteOrder; } public void setNextInVariableOrder(Node nextInWriteOrder) { this.nextInWriteOrder = nextInWriteOrder; } public long getVariableTime() { return UnsafeAccess.UNSAFE.getLong(this, WRITE_TIME_OFFSET); } public void setVariableTime(long writeTime) { UnsafeAccess.UNSAFE.putLong(this, WRITE_TIME_OFFSET, writeTime); } public boolean casVariableTime(long expect, long update) { return (writeTime == expect) && UnsafeAccess.UNSAFE.compareAndSwapLong(this, WRITE_TIME_OFFSET, expect, update); } public final long getWriteTime() { return UnsafeAccess.UNSAFE.getLong(this, WRITE_TIME_OFFSET); } public final void setWriteTime(long writeTime) { UnsafeAccess.UNSAFE.putLong(this, WRITE_TIME_OFFSET, writeTime); } public final Node getPreviousInWriteOrder() { return previousInWriteOrder; } public final void setPreviousInWriteOrder(Node previousInWriteOrder) { this.previousInWriteOrder = previousInWriteOrder; } public final Node getNextInWriteOrder() { return nextInWriteOrder; } public final void setNextInWriteOrder(Node nextInWriteOrder) { this.nextInWriteOrder = nextInWriteOrder; } public Node newNode(K key, ReferenceQueue keyReferenceQueue, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { return new FSAW<>(key, keyReferenceQueue, value, valueReferenceQueue, weight, now); } public Node newNode(Object keyReference, V value, ReferenceQueue valueReferenceQueue, int weight, long now) { return new FSAW<>(keyReference, value, valueReferenceQueue, weight, now); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy