SPIGOT-591: Optimize EntitySlice.iterator

Previously if the key 'this.c' was missing a new hashmap was created, this
caused thousands to be created each tick

By: Thinkofdeath <thinkofdeath@spigotmc.org>
This commit is contained in:
CraftBukkit/Spigot 2015-02-20 10:19:11 +00:00
parent f227bb34dc
commit fcb95ad15a
3 changed files with 42 additions and 0 deletions

View File

@ -0,0 +1,22 @@
--- ../work/decompile-8eb82bde/net/minecraft/server/EntitySlice.java 2015-02-20 10:18:42.025023871 +0000
+++ src/main/java/net/minecraft/server/EntitySlice.java 2015-02-20 10:18:42.057023871 +0000
@@ -4,6 +4,7 @@
import com.google.common.collect.Multimap;
import com.google.common.collect.Sets;
import java.util.AbstractSet;
+import java.util.Collections;
import java.util.Iterator;
import java.util.Set;
import org.apache.commons.lang3.ClassUtils;
@@ -89,6 +90,11 @@
}
public Iterator iterator() {
+ // CraftBukkit start
+ if (!this.a.containsKey(this.c)) {
+ return Collections.EMPTY_LIST.iterator();
+ }
+ // CraftBukkit end
Iterator iterator = this.a.get(this.c).iterator();
return new EntitySliceInnerClass2(this, iterator);

View File

@ -0,0 +1,10 @@
--- ../work/decompile-8eb82bde/net/minecraft/server/EntitySliceInnerClass1.java 2015-02-20 10:18:41.853023875 +0000
+++ src/main/java/net/minecraft/server/EntitySliceInnerClass1.java 2015-02-20 10:18:41.853023875 +0000
@@ -3,6 +3,7 @@
import com.google.common.collect.Iterators;
import java.util.Iterator;
+// PAIL: Access transform
class EntitySliceInnerClass1 implements Iterable {
final Class a;

View File

@ -0,0 +1,10 @@
--- ../work/decompile-8eb82bde/net/minecraft/server/EntitySliceInnerClass2.java 2015-02-20 10:18:41.945023873 +0000
+++ src/main/java/net/minecraft/server/EntitySliceInnerClass2.java 2015-02-20 10:18:41.965023873 +0000
@@ -3,6 +3,7 @@
import com.google.common.collect.AbstractIterator;
import java.util.Iterator;
+// PAIL: Access transform
class EntitySliceInnerClass2 extends AbstractIterator {
final Iterator a;