diff options
author | 2012-04-16 01:28:40 -0700 | |
---|---|---|
committer | 2012-04-16 01:28:40 -0700 | |
commit | 69cf85d8e3519e34ab6a9d6d19385c6ba7ab6623 (patch) | |
tree | d234263e2ce09233a8bd735a4561678b24b224a3 /native/jni/src | |
parent | 8b833071a14b8f367d00be4a338f2407ee312516 (diff) | |
parent | 3f675f70601575a2964a3a4f5d8fcd639446238d (diff) | |
download | latinime-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.h | 6 |
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() { |