diff options
| author | 2011-12-12 15:53:25 -0800 | |
|---|---|---|
| committer | 2011-12-12 15:53:25 -0800 | |
| commit | a1277de3c393fb0861d26ec5551ae4247e32dee4 (patch) | |
| tree | 77d2e5695a8b3f5ddc3e1b05087407b065324fde | |
| parent | 1fb90497b73b1560c55f1cb73cd394c3b8714212 (diff) | |
| parent | c3fb7a11ad72c5e51ff93e1ad6958f843af0d5b1 (diff) | |
Merge "Prevent a memory leak in TextLine." into ics-mr1
| -rw-r--r-- | core/java/android/text/TextLine.java | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/core/java/android/text/TextLine.java b/core/java/android/text/TextLine.java index b3df8ff5fbbc..303a30e13df7 100644 --- a/core/java/android/text/TextLine.java +++ b/core/java/android/text/TextLine.java @@ -102,6 +102,11 @@ class TextLine { tl.mText = null; tl.mPaint = null; tl.mDirections = null; + + tl.mMetricAffectingSpanSpanSet.recycle(); + tl.mCharacterStyleSpanSet.recycle(); + tl.mReplacementSpanSpanSet.recycle(); + synchronized(sCached) { for (int i = 0; i < sCached.length; ++i) { if (sCached[i] == null) { @@ -919,6 +924,12 @@ class TextLine { } return limit; } + + public void recycle() { + for (int i = 0; i < numberOfSpans; i++) { + spans[i] = null; // prevent a leak: no reference kept when TextLine is recycled + } + } } /** |