/*
 * Copyright Terracotta, Inc.
 *
 * 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 org.ehcache.config;

Represents a unit in which quantity is expressed in a SizedResourcePool.
/** * Represents a unit in which quantity is expressed in a {@link SizedResourcePool}. */
public interface ResourceUnit {
Compares thisSize in this unit to thatSize in thatUnit.

Returns 1, 0, or -1 if the thisSize of this is greater than, equal to, or less than thatSize of thatUnit respectively.

Params:
  • thisSize – size in this unit
  • thatSize – size in thatUnit
  • thatUnit – other ResourceUnit
Throws:
Returns:as per the compareTo contract
/** * Compares {@code thisSize} in this unit to {@code thatSize} in {@code thatUnit}. * <p> * Returns 1, 0, or -1 if the {@code thisSize} of {@code this} is greater than, * equal to, or less than {@code thatSize} of {@code thatUnit} * respectively. * * @param thisSize size in this unit * @param thatSize size in {@code thatUnit} * @param thatUnit other {@code ResourceUnit} * * @return as per the {@link Comparable#compareTo(Object) compareTo} contract * * @throws IllegalArgumentException if the units are not comparable */
int compareTo(long thisSize, long thatSize, ResourceUnit thatUnit) throws IllegalArgumentException; }