[android网络有效性检测] NetworkMonitor代码造成内存泄漏
造成内存泄漏的log如下:
E StrictMode: A resource was acquired at attached stack trace but never released. See java.io.Closeable for information on avoiding resource leaks.
E StrictMode: java.lang.Throwable: Explicit termination method 'end' not called
……
E StrictMode: at com.android.server.connectivity.NetworkMonitor.isCaptivePortalExt(NetworkMonitor.java:1026)
NetworkMonitor.java原来的代码如下,根据这段代码的意图,是想要获得请求的用时,然后通过一个名为 android.net.conn.NETWORK_CONDITIONS_MEASURED的广播发送出去。Key值为 extra_request_timestamp_ms 和extra_response_timestamp_ms(如果有的话)。
为什么会造成内存泄漏?
我发现该问题发生的场景是在我使用弱网络环境下,比如使用中国移动gprs上网这个时候会造成请求时间比较长,刚好如果有其他应用(比如Google music等)也在频繁的验证网络的连通性,并且机器的运存小的情况下就会造成内存资源泄露。
修改后如下:
获取InputStream对象,然后在适当的时候关闭,其实is.close()是可以放到
httpResponseCode = urlConnection.getResponseCode()之前的。
(版权所有,转载请告知)