mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-07 17:08:30 +01:00
Add IndexMap
This commit is contained in:
parent
d20cf85982
commit
dc9580b990
@ -1,7 +1,7 @@
|
|||||||
package net.minestom.server.tag;
|
package net.minestom.server.tag;
|
||||||
|
|
||||||
import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap;
|
|
||||||
import net.minestom.server.item.ItemStack;
|
import net.minestom.server.item.ItemStack;
|
||||||
|
import net.minestom.server.utils.collection.IndexMap;
|
||||||
import org.jetbrains.annotations.ApiStatus;
|
import org.jetbrains.annotations.ApiStatus;
|
||||||
import org.jetbrains.annotations.Contract;
|
import org.jetbrains.annotations.Contract;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@ -21,12 +21,7 @@ import java.util.function.Supplier;
|
|||||||
*/
|
*/
|
||||||
@ApiStatus.NonExtendable
|
@ApiStatus.NonExtendable
|
||||||
public class Tag<T> {
|
public class Tag<T> {
|
||||||
private static final Object2IntOpenHashMap<String> INDEX_MAP = new Object2IntOpenHashMap<>();
|
private static final IndexMap<String> INDEX_MAP = new IndexMap<>();
|
||||||
private static int lastIndex = 0; // Synchronized on INDEX_MAP
|
|
||||||
|
|
||||||
static {
|
|
||||||
INDEX_MAP.defaultReturnValue(-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
private final String key;
|
private final String key;
|
||||||
final Function<NBT, T> readFunction;
|
final Function<NBT, T> readFunction;
|
||||||
@ -43,21 +38,7 @@ public class Tag<T> {
|
|||||||
this.readFunction = readFunction;
|
this.readFunction = readFunction;
|
||||||
this.writeFunction = writeFunction;
|
this.writeFunction = writeFunction;
|
||||||
this.defaultValue = defaultValue;
|
this.defaultValue = defaultValue;
|
||||||
|
this.index = INDEX_MAP.get(key);
|
||||||
// Potentially very hot code!
|
|
||||||
// First try to get the index from the cpu cache
|
|
||||||
// If it's not there, synchronization is required
|
|
||||||
int index = INDEX_MAP.getInt(key);
|
|
||||||
if (index == -1) {
|
|
||||||
synchronized (INDEX_MAP) {
|
|
||||||
index = INDEX_MAP.getInt(key);
|
|
||||||
if (index == -1) {
|
|
||||||
index = lastIndex++;
|
|
||||||
INDEX_MAP.put(key, index);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.index = index;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static <T, N extends NBT> Tag<T> tag(@NotNull String key,
|
static <T, N extends NBT> Tag<T> tag(@NotNull String key,
|
||||||
|
@ -0,0 +1,30 @@
|
|||||||
|
package net.minestom.server.utils.collection;
|
||||||
|
|
||||||
|
import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap;
|
||||||
|
import org.jetbrains.annotations.ApiStatus;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@ApiStatus.Internal
|
||||||
|
public final class IndexMap<T> {
|
||||||
|
private final Object2IntOpenHashMap<T> indexMap;
|
||||||
|
private int lastIndex = 0; // Synchronized on INDEX_MAP
|
||||||
|
|
||||||
|
public IndexMap() {
|
||||||
|
this.indexMap = new Object2IntOpenHashMap<>();
|
||||||
|
indexMap.defaultReturnValue(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int get(@NotNull T key) {
|
||||||
|
int index = indexMap.getInt(key);
|
||||||
|
if (index == -1) {
|
||||||
|
synchronized (indexMap) {
|
||||||
|
index = indexMap.getInt(key);
|
||||||
|
if (index == -1) {
|
||||||
|
index = lastIndex++;
|
||||||
|
indexMap.put(key, index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return index;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user