Some performance or memory optimizations

Replaced String concat in loops with StringBuilder (performance)
Replaced for with keySet + Map.get() through for with entrySet (perf)
Changed inner classes to static classes, mostly struct like (memory)
This commit is contained in:
yueh 2014-09-30 22:59:49 +02:00
parent d8da97d2af
commit 7fa7e43c29
25 changed files with 86 additions and 80 deletions

View file

@ -33,7 +33,7 @@ import appeng.core.localization.ButtonToolTips;
public class GuiImgButton extends GuiButton implements ITooltip
{
class EnumPair
static class EnumPair
{
final Enum setting;
@ -63,7 +63,7 @@ public class GuiImgButton extends GuiButton implements ITooltip
}
class BtnAppearance
static class BtnAppearance
{
public int index;

View file

@ -23,7 +23,7 @@ public class RenderBlocksWorkaround extends RenderBlocks
public EnumSet<ForgeDirection> renderFaces = EnumSet.allOf( ForgeDirection.class );
public EnumSet<ForgeDirection> faces = EnumSet.allOf( ForgeDirection.class );
private class LightingCache implements ISimplifiedBundle
private static class LightingCache implements ISimplifiedBundle
{
public IIcon rXPos;

View file

@ -42,7 +42,7 @@ public class ContainerInterfaceTerminal extends AEBaseContainer
static private long autoBase = Long.MIN_VALUE;
class InvTracker
static class InvTracker
{
final long which = autoBase++;
@ -76,7 +76,7 @@ public class ContainerInterfaceTerminal extends AEBaseContainer
NBTTagCompound data = new NBTTagCompound();
class PatternInvSlot extends WrapperInvSlot
static class PatternInvSlot extends WrapperInvSlot
{
public PatternInvSlot(IInventory inv) {

View file

@ -196,7 +196,7 @@ public class ApiPart implements IPartHelper
}
}
class DefaultPackageClassNameRemapper extends Remapper
static class DefaultPackageClassNameRemapper extends Remapper
{
public final HashMap<String, String> inputOutput = new HashMap<String, String>();

View file

@ -9,7 +9,7 @@ import appeng.api.features.IWorldGen;
public class WorldGenRegistry implements IWorldGen
{
private class TypeSet
private static class TypeSet
{
final HashSet<Class<? extends WorldProvider>> badProviders = new HashSet<Class<? extends WorldProvider>>();

View file

@ -124,14 +124,14 @@ public class CraftingJob implements Runnable, ICraftingJob
missing.add( what );
}
class twoIntegers
static class TwoIntegers
{
public final long perOp = 0;
public final long times = 0;
}
final HashMap<String, twoIntegers> opsAndMultiplier = new HashMap<String, twoIntegers>();
final HashMap<String, TwoIntegers> opsAndMultiplier = new HashMap<String, TwoIntegers>();
@Override
public void run()
@ -154,7 +154,7 @@ public class CraftingJob implements Runnable, ICraftingJob
for (String s : opsAndMultiplier.keySet())
{
twoIntegers ti = opsAndMultiplier.get( s );
TwoIntegers ti = opsAndMultiplier.get( s );
AELog.crafting( s + " * " + ti.times + " = " + (ti.perOp * ti.times) );
}
@ -180,7 +180,7 @@ public class CraftingJob implements Runnable, ICraftingJob
for (String s : opsAndMultiplier.keySet())
{
twoIntegers ti = opsAndMultiplier.get( s );
TwoIntegers ti = opsAndMultiplier.get( s );
AELog.crafting( s + " * " + ti.times + " = " + (ti.perOp * ti.times) );
}

View file

@ -41,7 +41,7 @@ public class PatternHelper implements ICraftingPatternDetails, Comparable<Patter
final boolean isCrafting;
public int priority = 0;
class TestLookup
static class TestLookup
{
final int slot;

View file

@ -13,7 +13,7 @@ public class CompassManager
public static final CompassManager instance = new CompassManager();
class CompassRequest
static class CompassRequest
{
final int hash;

View file

@ -19,7 +19,7 @@ import cpw.mods.fml.common.IWorldGenerator;
final public class MeteoriteWorldGen implements IWorldGenerator
{
class myGen implements ICompassCallback
static class MyGen implements ICompassCallback
{
double distance = 0;

View file

@ -40,7 +40,7 @@ import cpw.mods.fml.common.gameevent.TickEvent.WorldTickEvent;
public class TickHandler
{
class HandlerRep
static class HandlerRep
{
public Queue<AEBaseTile> tiles = new LinkedList<AEBaseTile>();

View file

@ -60,7 +60,7 @@ public class ItemMultiMaterial extends AEBaseItem implements IStorageComponent,
instance = this;
}
class SlightlyBetterSort implements Comparator<String>
static class SlightlyBetterSort implements Comparator<String>
{
final Pattern p;

View file

@ -33,7 +33,7 @@ import cpw.mods.fml.relauncher.SideOnly;
public class ItemMultiPart extends AEBaseItem implements IPartItem, IItemGroup
{
class PartTypeIst
static class PartTypeIst
{
PartType part;

View file

@ -3,6 +3,7 @@ package appeng.me;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
import appeng.api.AEApi;
@ -34,10 +35,10 @@ public class Grid implements IGrid
this.pivot = center;
HashMap<Class<? extends IGridCache>, IGridCache> myCaches = AEApi.instance().registries().gridCache().createCacheInstance( this );
for (Class<? extends IGridCache> c : myCaches.keySet())
for (Entry<Class<? extends IGridCache>, IGridCache> c : myCaches.entrySet())
{
bus.readClass( c, myCaches.get( c ).getClass() );
caches.put( c, new GridCacheWrapper( myCaches.get( c ) ) );
bus.readClass( c.getKey(), c.getValue().getClass() );
caches.put( c.getKey(), new GridCacheWrapper( c.getValue() ) );
}
postEvent( new MENetworkPostCacheConstruction() );

View file

@ -4,6 +4,7 @@ import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.Map.Entry;
import java.util.Set;
import appeng.api.networking.IGridNode;
@ -14,7 +15,7 @@ import appeng.core.AELog;
public class NetworkEventBus
{
class NetworkEventDone extends Throwable
static class NetworkEventDone extends Throwable
{
private static final long serialVersionUID = -3079021487019171205L;
@ -129,17 +130,17 @@ public class NetworkEventBus
{
if ( subscribers != null )
{
for (Class o : subscribers.keySet())
for (Entry<Class, MENetworkEventInfo> subscriber : subscribers.entrySet())
{
MENetworkEventInfo target = subscribers.get( o );
GridCacheWrapper cache = g.caches.get( o );
MENetworkEventInfo target = subscriber.getValue();
GridCacheWrapper cache = g.caches.get( subscriber.getKey() );
if ( cache != null )
{
x++;
target.invoke( cache.myCache, e );
}
for (IGridNode obj : g.getMachines( o ))
for (IGridNode obj : g.getMachines( subscriber.getKey() ))
{
x++;
target.invoke( obj.getMachine(), e );

View file

@ -86,7 +86,7 @@ public class CraftingGridCache implements ICraftingGrid, ICraftingProviderHelper
final private SetMultimap<IAEStack, CraftingWatcher> interests = HashMultimap.create();
final public GenericInterestManager<CraftingWatcher> interestManager = new GenericInterestManager<CraftingWatcher>( interests );
class ActiveCpuIterator implements Iterator<ICraftingCPU>
static class ActiveCpuIterator implements Iterator<ICraftingCPU>
{
final Iterator<CraftingCPUCluster> i;

View file

@ -58,7 +58,7 @@ import cpw.mods.fml.common.FMLCommonHandler;
public class CraftingCPUCluster implements IAECluster, ICraftingCPU
{
class TaskProgress
static class TaskProgress
{
long value;

View file

@ -27,7 +27,7 @@ import appeng.util.inv.ItemSlot;
public class MEMonitorIInventory implements IMEInventory<IAEItemStack>, IMEMonitor<IAEItemStack>
{
class CachedItemStack
static class CachedItemStack
{
public CachedItemStack(ItemStack is)

View file

@ -31,10 +31,11 @@ public class ShapedRecipe implements IRecipe, IRecipeBakeable
return !disable;
}
public ShapedRecipe(ItemStack result, Object... recipe) {
public ShapedRecipe(ItemStack result, Object... recipe)
{
output = result.copy();
String shape = "";
StringBuilder shape = new StringBuilder();
int idx = 0;
if ( recipe[idx] instanceof Boolean )
@ -57,7 +58,7 @@ public class ShapedRecipe implements IRecipe, IRecipeBakeable
for (String s : parts)
{
width = s.length();
shape += s;
shape.append( s );
}
height = parts.length;
@ -67,7 +68,7 @@ public class ShapedRecipe implements IRecipe, IRecipeBakeable
while (recipe[idx] instanceof String)
{
String s = (String) recipe[idx++];
shape += s;
shape.append( s );
width = s.length();
height++;
}
@ -75,13 +76,13 @@ public class ShapedRecipe implements IRecipe, IRecipeBakeable
if ( width * height != shape.length() )
{
String ret = "Invalid shaped ore recipe: ";
StringBuilder ret = new StringBuilder( "Invalid shaped ore recipe: " );
for (Object tmp : recipe)
{
ret += tmp + ", ";
ret.append( tmp + ", " );
}
ret += output;
throw new RuntimeException( ret );
ret.append( output );
throw new RuntimeException( ret.toString() );
}
HashMap<Character, Object> itemMap = new HashMap<Character, Object>();
@ -97,19 +98,19 @@ public class ShapedRecipe implements IRecipe, IRecipeBakeable
}
else
{
String ret = "Invalid shaped ore recipe: ";
StringBuilder ret = new StringBuilder( "Invalid shaped ore recipe: " );
for (Object tmp : recipe)
{
ret += tmp + ", ";
ret.append( tmp + ", " );
}
ret += output;
throw new RuntimeException( ret );
ret.append( output );
throw new RuntimeException( ret.toString() );
}
}
input = new Object[width * height];
int x = 0;
for (char chr : shape.toCharArray())
for (char chr : shape.toString().toCharArray())
{
input[x++] = itemMap.get( chr );
}

View file

@ -24,7 +24,8 @@ public class ShapelessRecipe implements IRecipe, IRecipeBakeable
return !disable;
}
public ShapelessRecipe(ItemStack result, Object... recipe) {
public ShapelessRecipe(ItemStack result, Object... recipe)
{
output = result.copy();
for (Object in : recipe)
{
@ -34,13 +35,13 @@ public class ShapelessRecipe implements IRecipe, IRecipeBakeable
}
else
{
String ret = "Invalid shapeless ore recipe: ";
StringBuilder ret = new StringBuilder( "Invalid shapeless ore recipe: " );
for (Object tmp : recipe)
{
ret += tmp + ", ";
ret.append( tmp + ", " );
}
ret += output;
throw new RuntimeException( ret );
ret.append( output );
throw new RuntimeException( ret.toString() );
}
}
}

View file

@ -64,21 +64,21 @@ public class Shaped implements ICraftHandler, IWebsiteSerializer
for (int y = 0; y < rows; y++)
{
String row = "";
StringBuilder row = new StringBuilder();
for (int x = 0; x < cols; x++)
{
if ( inputs.get( y ).get( x ).isAir() )
row = row + " ";
row.append( " " );
else
{
row = row + first;
row.append( first );
args.add( first );
args.add( inputs.get( y ).get( x ) );
first++;
}
}
args.add( y, row );
args.add( y, row.toString() );
}
ItemStack outIS = output.getItemStack();

View file

@ -57,9 +57,10 @@ public class Shapeless implements ICraftHandler, IWebsiteSerializer
throw new RegistrationError( "Error while adding shapeless recipe." );
}
}
@Override
public boolean canCraft(ItemStack reqOutput) throws RegistrationError, MissingIngredientError {
public boolean canCraft(ItemStack reqOutput) throws RegistrationError, MissingIngredientError
{
for (IIngredient i : inputs)
{
@ -74,26 +75,27 @@ public class Shapeless implements ICraftHandler, IWebsiteSerializer
}
}
}
return Platform.isSameItemPrecise( output.getItemStack(),reqOutput );
return Platform.isSameItemPrecise( output.getItemStack(), reqOutput );
}
@Override
public String getPattern( RecipeHandler h) {
String o = "shapeless "+output.getQty()+"\n";
public String getPattern(RecipeHandler h)
{
StringBuilder o = new StringBuilder( "shapeless " + output.getQty() + "\n" );
o += h.getName(output)+"\n";
for ( int y = 0; y < inputs.size(); y++ )
o.append( h.getName( output ) + "\n" );
for (int y = 0; y < inputs.size(); y++)
{
IIngredient i = inputs.get(y);
IIngredient i = inputs.get( y );
if ( i.isAir() )
o += "air"+( y +1 == inputs.size() ? "\n" : " " );
o.append( "air" + (y + 1 == inputs.size() ? "\n" : " ") );
else
o += h.getName(i)+( y +1 == inputs.size() ? "\n" : " " );
o.append( h.getName( i ) + (y + 1 == inputs.size() ? "\n" : " ") );
}
return o.trim();
return o.toString().trim();
}
}

View file

@ -60,17 +60,17 @@ public class VersionChecker implements Runnable
yc.setRequestProperty( "User-Agent", "AE2/" + AEConfig.VERSION + " (Channel:" + AEConfig.CHANNEL + "," + MCVersion.replace( " ", ":" ) + ")" );
BufferedReader in = new BufferedReader( new InputStreamReader( yc.getInputStream() ) );
String Version = "";
StringBuilder Version = new StringBuilder();
String inputLine;
while ((inputLine = in.readLine()) != null)
Version += inputLine;
Version.append( inputLine );
in.close();
if ( Version.length() > 2 )
{
JsonElement element = (new JsonParser()).parse( Version );
JsonElement element = (new JsonParser()).parse( Version.toString() );
int version = element.getAsJsonObject().get( "FormatVersion" ).getAsInt();
if ( version == 1 )

View file

@ -31,12 +31,12 @@ public class StorageHelper
return instance;
}
class triggerUpdates implements ISpatialVisitor
static class TriggerUpdates implements ISpatialVisitor
{
final World dst;
public triggerUpdates(World dst2) {
public TriggerUpdates(World dst2) {
dst = dst2;
}
@ -48,7 +48,7 @@ public class StorageHelper
}
}
class WrapInMatrixFrame implements ISpatialVisitor
static class WrapInMatrixFrame implements ISpatialVisitor
{
final World dst;
@ -68,7 +68,7 @@ public class StorageHelper
}
}
class TelDestination
static class TelDestination
{
TelDestination(World _dim, AxisAlignedBB srcBox, double _x, double _y, double _z, int tileX, int tileY, int tileZ) {
@ -91,7 +91,7 @@ public class StorageHelper
final int zOff;
}
class METeleporter extends Teleporter
static class METeleporter extends Teleporter
{
final TelDestination dest;
@ -303,11 +303,11 @@ public class StorageHelper
for (WorldCoord wc : cSrc.updates)
cSrc.world.notifyBlockOfNeighborChange( wc.x, wc.y, wc.z, Platform.air );
transverseEdges( x - 1, y - 1, z - 1, x + scaleX + 1, y + scaleY + 1, z + scaleZ + 1, new triggerUpdates( src ) );
transverseEdges( i - 1, j - 1, k - 1, i + scaleX + 1, j + scaleY + 1, k + scaleZ + 1, new triggerUpdates( dst ) );
transverseEdges( x - 1, y - 1, z - 1, x + scaleX + 1, y + scaleY + 1, z + scaleZ + 1, new TriggerUpdates( src ) );
transverseEdges( i - 1, j - 1, k - 1, i + scaleX + 1, j + scaleY + 1, k + scaleZ + 1, new TriggerUpdates( dst ) );
transverseEdges( x, y, z, x + scaleX, y + scaleY, z + scaleZ, new triggerUpdates( src ) );
transverseEdges( i, j, k, i + scaleX, j + scaleY, k + scaleZ, new triggerUpdates( dst ) );
transverseEdges( x, y, z, x + scaleX, y + scaleY, z + scaleZ, new TriggerUpdates( src ) );
transverseEdges( i, j, k, i + scaleX, j + scaleY, k + scaleZ, new TriggerUpdates( dst ) );
/*
* IChunkProvider cp = dest.getChunkProvider(); if ( cp instanceof ChunkProviderServer ) { ChunkProviderServer

View file

@ -13,7 +13,7 @@ import net.minecraft.item.ItemStack;
public class WrapperChainedInventory implements IInventory
{
class InvOffset
static class InvOffset
{
int offset;

View file

@ -13,7 +13,7 @@ public class OreHelper
public static final OreHelper instance = new OreHelper();
class ItemRef
static class ItemRef
{
ItemRef(ItemStack stack)
@ -51,7 +51,7 @@ public class OreHelper
}
class OreResult
static class OreResult
{
public OreReference oreValue = null;