From b2c7dd5986344369f02dfe2965b309153b121127 Mon Sep 17 00:00:00 2001 From: Xavier Ducrohet Date: Wed, 23 Feb 2011 15:02:58 -0800 Subject: LayoutLib: downsize the SparseArray when possible. Change-Id: I570b93ab161414b7729f8d2dce8ddadb706f186b --- .../com/android/layoutlib/bridge/util/SparseWeakArray.java | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'tools') diff --git a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/SparseWeakArray.java b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/SparseWeakArray.java index 22f1609..4d0c9ce 100644 --- a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/SparseWeakArray.java +++ b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/SparseWeakArray.java @@ -119,8 +119,6 @@ public class SparseWeakArray { } private void gc() { - // Log.e("SparseArray", "gc start with " + mSize); - int n = mSize; int o = 0; int[] keys = mKeys; @@ -144,7 +142,17 @@ public class SparseWeakArray { mGarbage = false; mSize = o; - // Log.e("SparseArray", "gc end with " + mSize); + int newSize = ArrayUtils.idealIntArraySize(mSize); + if (newSize < mKeys.length) { + int[] nkeys = new int[newSize]; + WeakReference[] nvalues = new WeakReference[newSize]; + + System.arraycopy(mKeys, 0, nkeys, 0, newSize); + System.arraycopy(mValues, 0, nvalues, 0, newSize); + + mKeys = nkeys; + mValues = nvalues; + } } /** -- cgit v1.1