如何避免网络变化的多次广播

相信做网络监听的同学会发现,网络变化时,广播通知会发送多次,至于为什么,自行查阅资料。但多次广播对我们处理业务逻辑很是恼人,其实我们只需要做小小调整就可以避免这种问题
如下代码,记得注释中delay的地方,最好在自己的代码中控制下,以免网络还未真正建立起来,5秒足够。

01/**
02 *
03 */
04 
05package com.ckt.vas.hhl.receiver;
06 
07import org.slf4j.Logger;
08import org.slf4j.LoggerFactory;
09 
10import android.content.BroadcastReceiver;
11import android.content.Context;
12import android.content.Intent;
13import android.net.ConnectivityManager;
14import android.net.NetworkInfo;
15 
16/**
17 * @author Gauss
18 */
19public class NetConnectionReceiver extends BroadcastReceiver {
20        private final Logger log = LoggerFactory.getLogger(NetConnectionReceiver.class);
21 
22        private static int lastType = -1;
23 
24        @Override
25        public void onReceive(Context context, Intent arg1) {
26                // log.debug("网络状态改变");
27                String action = arg1.getAction();
28                log.debug("网络状态改变 action=" + action + " lastType=" + lastType);
29                // 获得网络连接服务
30                ConnectivityManager connManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
31 
32                NetworkInfo info = connManager.getActiveNetworkInfo();
33 
34                if (info == null || !connManager.getBackgroundDataSetting()) {
35                        log.info("您的网络连接已中断");
36                } else {
37                        int netType = info.getType();
38                        if (netType != lastType) {
39                                if (info.isConnected()) {
40                                        //delay 5seconds
41                                        log.warn("new connection was create.........type:" + info.getTypeName() + " status"
42                                                        + info.getDetailedState());
43                                } else {
44                                        //delay 5seconds
45                                        log.warn("the connection was broken...........type:" + info.getTypeName() + " status"
46                                                        + info.getDetailedState());
47                                }
48                                lastType = netType;
49                        }
50 
51                }
52        }
53 
54}
转自:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=193562
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值