aboutsummaryrefslogtreecommitdiffstats
path: root/native/jni/src
diff options
context:
space:
mode:
authorJean Chalard <jchalard@google.com>2012-04-16 01:28:40 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-04-16 01:28:40 -0700
commit69cf85d8e3519e34ab6a9d6d19385c6ba7ab6623 (patch)
treed234263e2ce09233a8bd735a4561678b24b224a3 /native/jni/src
parent8b833071a14b8f367d00be4a338f2407ee312516 (diff)
parent3f675f70601575a2964a3a4f5d8fcd639446238d (diff)
downloadlatinime-69cf85d8e3519e34ab6a9d6d19385c6ba7ab6623.tar.gz
latinime-69cf85d8e3519e34ab6a9d6d19385c6ba7ab6623.tar.xz
latinime-69cf85d8e3519e34ab6a9d6d19385c6ba7ab6623.zip
Merge "Fix a large native memory leak."
Diffstat (limited to 'native/jni/src')
-rw-r--r--native/jni/src/words_priority_queue_pool.h6
1 files changed, 6 insertions, 0 deletions
diff --git a/native/jni/src/words_priority_queue_pool.h b/native/jni/src/words_priority_queue_pool.h
index 5b50e8f4f..210b5a848 100644
--- a/native/jni/src/words_priority_queue_pool.h
+++ b/native/jni/src/words_priority_queue_pool.h
@@ -26,6 +26,7 @@ namespace latinime {
class WordsPriorityQueuePool {
public:
WordsPriorityQueuePool(int mainQueueMaxWords, int subQueueMaxWords, int maxWordLength) {
+ // Note: using placement new() requires the caller to call the destructor explicitly.
mMasterQueue = new(mMasterQueueBuf) WordsPriorityQueue(mainQueueMaxWords, maxWordLength);
for (int i = 0, subQueueBufOffset = 0;
i < MULTIPLE_WORDS_SUGGESTION_MAX_WORDS * SUB_QUEUE_MAX_COUNT;
@@ -36,6 +37,11 @@ class WordsPriorityQueuePool {
}
virtual ~WordsPriorityQueuePool() {
+ // Note: these explicit calls to the destructor match the calls to placement new() above.
+ if (mMasterQueue) mMasterQueue->~WordsPriorityQueue();
+ for (int i = 0; i < MULTIPLE_WORDS_SUGGESTION_MAX_WORDS * SUB_QUEUE_MAX_COUNT; ++i) {
+ if (mSubQueues[i]) mSubQueues[i]->~WordsPriorityQueue();
+ }
}
WordsPriorityQueue* getMasterQueue() {