造成内存泄漏的log如下:

[android网络有效性检测] NetworkMonitor代码造成内存泄漏-LMLPHP

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(如果有的话)。

[android网络有效性检测] NetworkMonitor代码造成内存泄漏-LMLPHP

为什么会造成内存泄漏?

我发现该问题发生的场景是在我使用弱网络环境下,比如使用中国移动gprs上网这个时候会造成请求时间比较长,刚好如果有其他应用(比如Google music等)也在频繁的验证网络的连通性,并且机器的运存小的情况下就会造成内存资源泄露。

修改后如下:

[android网络有效性检测] NetworkMonitor代码造成内存泄漏-LMLPHP

获取InputStream对象,然后在适当的时候关闭,其实is.close()是可以放到

httpResponseCode = urlConnection.getResponseCode()之前的。

(版权所有,转载请告知)

05-11 16:14