public void register() { if (isRegister.get()) { LogUtils.e(TAG, "apmReceiver already register..."); return; } LogUtils.i(TAG,"apmReceiver register...." ); isRegister.set(true); IntentFilter intentFilter = new IntentFilter(); intentFilter.addAction(Intent.ACTION_BATTERY_CHANGED); intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE"); context.registerReceiver(apmReceiver, intentFilter); networkType = JJDataUtils.getNetworkType(context); jjApmSDKImpl = JJApmSDKImpl.getApmIpmAfterInit(); }
时间: 2024-02-14 20:33:27 浏览: 203
这段代码主要是注册一个 BroadcastReceiver 监听电量变化和网络状态变化,并且在注册之前进行了判断,避免重复注册。优化建议如下:
1. 可以将 isRegister 的判断放到 context.registerReceiver 方法的内部,这样可以避免在多线程环境下出现并发问题。
2. 可以将 intentFilter 的初始化和 addAction 方法的调用合并到一起,这样可以减少代码量。
3. 可以将 BroadcastReceiver 的实例化放到方法内部,并且使用匿名内部类来实现,可以避免在类中定义过多的实例变量。
4. 在注册 BroadcastReceiver 之前,可以先判断 context 是否为 null,以避免出现空指针异常。
下面是优化后的代码:
public void register() {
if (isRegister.get()) {
LogUtils.e(TAG, "apmReceiver already register...");
return;
}
isRegister.set(true);
if (context == null) {
LogUtils.e(TAG, "context is null, cannot register apmReceiver!");
return;
}
LogUtils.i(TAG, "apmReceiver register....");
IntentFilter intentFilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
context.registerReceiver(new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
if (Intent.ACTION_BATTERY_CHANGED.equals(intent.getAction())) {
// 处理电量变化
} else if ("android.net.conn.CONNECTIVITY_CHANGE".equals(intent.getAction())) {
// 处理网络状态变化
}
}
}, intentFilter);
networkType = JJDataUtils.getNetworkType(context);
jjApmSDKImpl = JJApmSDKImpl.getApmIpmAfterInit();
}
阅读全文