2016-03-22 06:46:32 +01:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Thu, 27 Aug 2015 01:15:02 -0400
|
|
|
|
Subject: [PATCH] Optimize Chunk Access
|
|
|
|
|
|
|
|
getting a loaded chunk is one of the most hottest pieces of code in the game.
|
2016-03-23 04:44:35 +01:00
|
|
|
getChunkAt is called for the same chunk multiple times in a row, often from getType();
|
2016-03-22 06:46:32 +01:00
|
|
|
|
|
|
|
Optimize this look up by using a Last Access cache.
|
|
|
|
|
2018-07-15 03:53:17 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkMap.java b/src/main/java/net/minecraft/server/ChunkMap.java
|
2018-08-27 06:15:12 +02:00
|
|
|
index fbebd4591c..b941676829 100644
|
2018-07-15 03:53:17 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkMap.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkMap.java
|
2018-08-27 06:15:12 +02:00
|
|
|
@@ -0,0 +0,0 @@ public class ChunkMap extends Long2ObjectOpenHashMap<Chunk> {
|
|
|
|
|
|
|
|
public Chunk a(long i, Chunk chunk) {
|
|
|
|
chunk.world.timings.syncChunkLoadPostTimer.startTiming(); // Paper
|
|
|
|
+ lastChunkByPos = chunk; // Paper
|
|
|
|
Chunk chunk1 = (Chunk) super.put(i, chunk);
|
|
|
|
ChunkCoordIntPair chunkcoordintpair = new ChunkCoordIntPair(i);
|
|
|
|
|
2018-07-15 03:53:17 +02:00
|
|
|
@@ -0,0 +0,0 @@ public class ChunkMap extends Long2ObjectOpenHashMap<Chunk> {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ if (lastChunkByPos != null && i == lastChunkByPos.chunkKey) {
|
|
|
|
+ lastChunkByPos = null;
|
2016-03-22 06:46:32 +01:00
|
|
|
+ }
|
2018-07-15 03:53:17 +02:00
|
|
|
return chunk;
|
|
|
|
}
|
2018-08-27 06:15:12 +02:00
|
|
|
+ private Chunk lastChunkByPos = null;
|
2016-04-01 06:35:44 +02:00
|
|
|
+
|
2018-07-15 03:53:17 +02:00
|
|
|
+ @Override
|
|
|
|
+ public Chunk get(long l) {
|
|
|
|
+ if (lastChunkByPos != null && l == lastChunkByPos.chunkKey) {
|
|
|
|
+ return lastChunkByPos;
|
2016-04-01 06:35:44 +02:00
|
|
|
+ }
|
2018-08-27 06:15:12 +02:00
|
|
|
+ return lastChunkByPos = super.get(l);
|
2018-07-15 03:53:17 +02:00
|
|
|
+ }
|
2016-03-22 06:46:32 +01:00
|
|
|
+ // Paper end
|
2016-05-12 04:07:46 +02:00
|
|
|
|
2018-07-15 03:53:17 +02:00
|
|
|
public Chunk a(Object object) {
|
|
|
|
return this.a(((Long) object).longValue());
|
2018-08-27 06:15:12 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkProviderServer.java b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
2018-09-11 04:38:42 +02:00
|
|
|
index d73034f329..b1e6901090 100644
|
2018-08-27 06:15:12 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
|
|
|
@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider {
|
|
|
|
Chunk chunk;
|
|
|
|
|
|
|
|
synchronized (this.chunkLoader) {
|
|
|
|
- if (this.lastChunk != null && this.lastChunk.getPos().x == i && this.lastChunk.getPos().z == j) {
|
|
|
|
+ // Paper start - remove vanilla lastChunk, we do it more accurately
|
|
|
|
+ /* if (this.lastChunk != null && this.lastChunk.locX == i && this.lastChunk.locZ == j) {
|
|
|
|
return this.lastChunk;
|
|
|
|
- }
|
|
|
|
+ }*/ // Paper end
|
|
|
|
|
|
|
|
long k = ChunkCoordIntPair.a(i, j);
|
|
|
|
|
|
|
|
chunk = (Chunk) this.chunks.get(k);
|
|
|
|
if (chunk != null) {
|
|
|
|
- this.lastChunk = chunk;
|
|
|
|
+ //this.lastChunk = chunk; // Paper remove vanilla lastChunk
|
|
|
|
return chunk;
|
|
|
|
}
|
|
|
|
|
|
|
|
@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider {
|
|
|
|
}
|
|
|
|
|
|
|
|
this.chunks.put(k, chunk);
|
|
|
|
- this.lastChunk = chunk;
|
|
|
|
+ //this.lastChunk = chunk; // Paper
|
|
|
|
}
|
|
|
|
|
|
|
|
this.asyncTaskHandler.postToMainThread(chunk::addEntities);
|
|
|
|
@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider {
|
2018-09-11 04:38:42 +02:00
|
|
|
this.saveChunk(chunk, true); // Spigot
|
|
|
|
}
|
|
|
|
this.chunks.remove(chunk.chunkKey);
|
|
|
|
- this.lastChunk = null;
|
|
|
|
+ // this.lastChunk = null; // Paper
|
2018-08-27 06:15:12 +02:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2016-03-22 06:46:32 +01:00
|
|
|
--
|