From e86749febd16fe3afb1aef448a2f0eae318fdcf7 Mon Sep 17 00:00:00 2001 From: FatBoy-DOTC Date: Sat, 18 Jan 2025 03:15:48 -0600 Subject: [PATCH] optimized bane thread --- src/engine/workthreads/BaneThread.java | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/src/engine/workthreads/BaneThread.java b/src/engine/workthreads/BaneThread.java index 66cb0d72..ddee5959 100644 --- a/src/engine/workthreads/BaneThread.java +++ b/src/engine/workthreads/BaneThread.java @@ -27,8 +27,8 @@ import java.util.ArrayList; public class BaneThread implements Runnable { - public Long lastRun; - public static int instancedelay = 10000; + private volatile Long lastRun; + public static final Long instancedelay = 1000L; public BaneThread() { Logger.info(" BaneThread thread has started!"); } @@ -37,14 +37,16 @@ public class BaneThread implements Runnable { public void processBanesWindow() { try { - for(int baneId : Bane.banes.keySet()){ - Bane bane = Bane.banes.get(baneId); - if(bane.getSiegePhase().equals(Enum.SiegePhase.WAR)){ - bane.applyZergBuffs(); + synchronized (Bane.banes) { + for (int baneId : Bane.banes.keySet()) { + Bane bane = Bane.banes.get(baneId); + if (bane != null && bane.getSiegePhase().equals(Enum.SiegePhase.WAR)) { + bane.applyZergBuffs(); + } } } } catch (Exception e) { - Logger.error("BANE ERROR"); + Logger.error("BANE ERROR",e); } @@ -56,6 +58,13 @@ public class BaneThread implements Runnable { if (System.currentTimeMillis() >= lastRun + instancedelay) { // Correct condition this.processBanesWindow(); lastRun = System.currentTimeMillis(); // Update lastRun after processing + }else { + try { + Thread.sleep(100); // Pause for 10ms to reduce CPU usage + } catch (InterruptedException e) { + Logger.error("Thread interrupted", e); + Thread.currentThread().interrupt(); + } } } }