Resize UnsafeList to initial capacity when cleared and implement clone.

By: Travis Watkins <amaranth@ubuntu.com>
This commit is contained in:
CraftBukkit/Spigot 2012-05-31 20:14:28 -05:00
parent d7d484d6aa
commit 8716e36905

View File

@ -5,21 +5,22 @@ import java.io.ObjectInputStream;
import java.io.ObjectOutputStream; import java.io.ObjectOutputStream;
import java.io.Serializable; import java.io.Serializable;
import java.util.AbstractList; import java.util.AbstractList;
import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.RandomAccess; import java.util.RandomAccess;
// implementation of an ArrayList that offers a getter without range checks // implementation of an ArrayList that offers a getter without range checks
public class UnsafeList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, Serializable { public class UnsafeList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, Serializable {
private static final long serialVersionUID = 8683452581112892189L; private static final long serialVersionUID = 8683452581112892190L;
private transient Object[] data; private transient Object[] data;
private int size; private int size;
private int initialCapacity;
public UnsafeList(int capacity) { public UnsafeList(int capacity) {
super(); super();
if (capacity < 0) capacity = 128; if (capacity < 0) capacity = 128;
int rounded = Integer.highestOneBit(capacity - 1) << 1; int rounded = Integer.highestOneBit(capacity - 1) << 1;
data = new Object[rounded]; data = new Object[rounded];
initialCapacity = rounded;
} }
public UnsafeList() { public UnsafeList() {
@ -95,11 +96,9 @@ public class UnsafeList<E> extends AbstractList<E> implements List<E>, RandomAcc
} }
public void clear() { public void clear() {
for (int i = 0; i < size; i++) { // Create new array to reset memory usage to initial capacity
data[i] = null;
}
size = 0; size = 0;
data = new Object[initialCapacity];
} }
// actually rounds up to nearest power of two // actually rounds up to nearest power of two
@ -137,6 +136,7 @@ public class UnsafeList<E> extends AbstractList<E> implements List<E>, RandomAcc
os.defaultWriteObject(); os.defaultWriteObject();
os.writeInt(size); os.writeInt(size);
os.writeInt(initialCapacity);
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
os.writeObject(data[i]); os.writeObject(data[i]);
} }
@ -146,9 +146,23 @@ public class UnsafeList<E> extends AbstractList<E> implements List<E>, RandomAcc
is.defaultReadObject(); is.defaultReadObject();
size = is.readInt(); size = is.readInt();
initialCapacity = is.readInt();
data = new Object[Integer.highestOneBit(size - 1) << 1]; data = new Object[Integer.highestOneBit(size - 1) << 1];
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
data[i] = is.readObject(); data[i] = is.readObject();
} }
} }
public UnsafeList<E> clone() {
try {
UnsafeList<E> copy = (UnsafeList<E>) super.clone();
copy.data = Java15Compat.Arrays_copyOf(data, size);
copy.size = size;
copy.initialCapacity = initialCapacity;
return copy;
} catch (CloneNotSupportedException ex) {
// This should never happen
return null;
}
}
} }