From 0dc4f76558f911bbf03a3f2a7581b57e3ad264eb Mon Sep 17 00:00:00 2001 From: IzzelAliz Date: Sat, 12 Feb 2022 21:28:41 +0800 Subject: [PATCH] Optimize Util#sequence (#7115) Basically the same diff is already in Vanilla 22w06a, so might as well merge this now/have a conflict to know to remove the stream they added --- patches/server/Optimize-Util-sequence.patch | 44 +++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 patches/server/Optimize-Util-sequence.patch diff --git a/patches/server/Optimize-Util-sequence.patch b/patches/server/Optimize-Util-sequence.patch new file mode 100644 index 0000000000..9bb08162b3 --- /dev/null +++ b/patches/server/Optimize-Util-sequence.patch @@ -0,0 +1,44 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: IzzelAliz +Date: Tue, 14 Dec 2021 12:43:03 +0800 +Subject: [PATCH] Optimize Util#sequence + +Original method allocates O(n^2) memory on n-size list. + +diff --git a/src/main/java/net/minecraft/Util.java b/src/main/java/net/minecraft/Util.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/Util.java ++++ b/src/main/java/net/minecraft/Util.java +@@ -0,0 +0,0 @@ public class Util { + return (Strategy) Util.IdentityStrategy.INSTANCE; // Paper - decompile fix + } + ++ private static final CompletableFuture[] EMPTY_FUTURE = new CompletableFuture[0]; // Paper + public static CompletableFuture> sequence(List> futures) { +- return futures.stream().reduce(CompletableFuture.completedFuture(Lists.newArrayList()), (completableFuture, completableFuture2) -> { +- return completableFuture2.thenCombine(completableFuture, (object, list) -> { +- List list2 = Lists.newArrayListWithCapacity(list.size() + 1); +- list2.addAll(list); +- list2.add(object); +- return list2; +- }); +- }, (completableFuture, completableFuture2) -> { +- return completableFuture.thenCombine(completableFuture2, (list, list2) -> { +- List list3 = Lists.newArrayListWithCapacity(list.size() + list2.size()); +- list3.addAll(list); +- list3.addAll(list2); +- return list3; ++ // Paper start - optimize ++ return CompletableFuture.allOf(futures.toArray(EMPTY_FUTURE)) ++ .thenApply(v -> { ++ List list = Lists.newArrayListWithCapacity(futures.size()); ++ for (CompletableFuture future : futures) { ++ list.add(future.join()); ++ } ++ return list; + }); +- }); ++ // Paper end + } + + public static CompletableFuture> sequenceFailFast(List> futures) {