Java tutorial
/** * Copyright 2015 Palantir Technologies * * Licensed under the BSD-3 License (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://opensource.org/licenses/BSD-3-Clause * * 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.palantir.lock; import java.util.Arrays; import java.util.Collection; import java.util.Map; import java.util.Set; import com.google.common.collect.Iterables; /** * Replacement for when you would normally use SortedMap<T, LockMode>, * but don't actually need the keys to be a set, or to have random * lookup of values. */ public class SortedLockCollection<T> extends LockCollection<T> implements Set<T> { private static final long serialVersionUID = 1L; SortedLockCollection(Collection<Map.Entry<T, LockMode>> locks) { super(locks); } @Override public String toString() { return "SortedLockCollection " + Iterables.toString(entries()); } @Override public boolean contains(Object o) { return Arrays.binarySearch(keys, o) >= 0; } }