snikket-im / snikket-android

Snikket Android client
https://snikket.org/app/
GNU General Public License v3.0
97 stars 18 forks source link

Activity memory leak caused by anonymous threads #43

Open cuixiaoyiyi opened 2 years ago

cuixiaoyiyi commented 2 years ago

Possible Memory Leak

An anonymous inner class will hold a reference to the this pointer of the outer class and will not be released until the thread ends. It will hold the Activity and prevent its timely release. Please check the links below.

Occurrences

https://github.com/snikket-im/snikket-android/blob/master/src/main/java/eu/siacs/conversations/ui/RecordingActivity.java#L140 https://github.com/snikket-im/snikket-android/blob/master/src/main/java/eu/siacs/conversations/ui/RtpSessionActivity.java#L320

Possible Solution

If it is necessary, it can be changed to static class + weak reference to eliminate the reference to the activity, which may cause memory leaks. Further discussion is welcome.