diff options
author | Kenny Root <kroot@google.com> | 2010-09-03 17:07:15 -0700 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2010-09-03 17:07:15 -0700 |
commit | a060b5f73863f4b5f161674a9c5ac0a0d8d76072 (patch) | |
tree | 1590b8f3c857bc8a4f5e9a4bb3c017a946556765 | |
parent | 783f14ddc9e4032b72aed7880aeb9d39970c98b7 (diff) | |
parent | 6dc003a73f7f01aa5dd5831e777e2aa44f65b032 (diff) | |
download | frameworks_base-a060b5f73863f4b5f161674a9c5ac0a0d8d76072.zip frameworks_base-a060b5f73863f4b5f161674a9c5ac0a0d8d76072.tar.gz frameworks_base-a060b5f73863f4b5f161674a9c5ac0a0d8d76072.tar.bz2 |
am 6dc003a7: Merge "Reduce footprint of Signature from ~7000 to ~1448" into gingerbread
Merge commit '6dc003a73f7f01aa5dd5831e777e2aa44f65b032' into gingerbread-plus-aosp
* commit '6dc003a73f7f01aa5dd5831e777e2aa44f65b032':
Reduce footprint of Signature from ~7000 to ~1448
-rw-r--r-- | core/java/android/content/pm/Signature.java | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/core/java/android/content/pm/Signature.java b/core/java/android/content/pm/Signature.java index 1bb3857..d4e5cc1 100644 --- a/core/java/android/content/pm/Signature.java +++ b/core/java/android/content/pm/Signature.java @@ -20,6 +20,7 @@ import android.content.ComponentName; import android.os.Parcel; import android.os.Parcelable; +import java.lang.ref.SoftReference; import java.util.Arrays; /** @@ -30,7 +31,7 @@ public class Signature implements Parcelable { private final byte[] mSignature; private int mHashCode; private boolean mHaveHashCode; - private String mString; + private SoftReference<String> mStringRef; /** * Create Signature from an existing raw byte array. @@ -96,10 +97,13 @@ public class Signature implements Parcelable { * cached so future calls will return the same String. */ public String toCharsString() { - if (mString != null) return mString; - String str = new String(toChars()); - mString = str; - return mString; + String str = mStringRef == null ? null : mStringRef.get(); + if (str != null) { + return str; + } + str = new String(toChars()); + mStringRef = new SoftReference<String>(str); + return str; } /** |