summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKenny Root <kroot@google.com>2010-09-03 17:07:15 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2010-09-03 17:07:15 -0700
commita060b5f73863f4b5f161674a9c5ac0a0d8d76072 (patch)
tree1590b8f3c857bc8a4f5e9a4bb3c017a946556765
parent783f14ddc9e4032b72aed7880aeb9d39970c98b7 (diff)
parent6dc003a73f7f01aa5dd5831e777e2aa44f65b032 (diff)
downloadframeworks_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.java14
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;
}
/**