博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Android Traffic] 调整定时更新的频率(C2DM与退避算法)
阅读量:6173 次
发布时间:2019-06-21

本文共 2407 字,大约阅读时间需要 8 分钟。

转载自: http://blog.csdn.net/kesenhoo/article/details/7395253

Minimizing the Effect of Regular Updates[最小化定时更新操作的副作用]

  • 最佳的定时更新频率是不确定的,通常由设备状态,网络连接状态,用户行为与用户定义明确的偏好而决定。
  • 这一章有讨论如何根据设备状态来修改更新频率。里面介绍了当断开网络连接的时候去关闭后台服务,在电量比较低的时候减少更新的频率。
  • 这一课会介绍更新频率是多少才会使得更新操作对无线电状态机的影响最小。
  • C2DM指数退避算法的使用

Use Cloud to Device Messaging as an Alternative to Polling[使用C2DM作为轮询方式之一]

关于详情 ,请参考:
  • 每次app去向server询问检查是否有更新操作的时候会激活无线电,这样造成了不必要的能量消耗(在3G情况下,会差不多消耗20秒的能量)。
  • C2DM是一个用来从server到特定app传输数据的轻量级的机制。使用C2DM,server会在某个app有新数据的时候通知app有这个消息[有点像PUSH短信的类型]。
  • 比起轮询方式(app为了即时拿到最新的数据需要定时向server请求数据),C2DM这种有事件驱动的模式会在仅仅有数据更新的时候通知app去创建网络连接来获取数据[很显然这样减少了app的大量操作,当然也减少了很多电量]。
  • C2DM需要通过使用固定TCP/IP来实现操作。当在你的设备上可以实现固定IP的时候,最好使用C2DM。[这个地方应该不是传统意义上的固定IP,可以理解为某个会话情况下]。很明显,使用C2DM既减少了网络连接次数,也优化了带宽,还减少了对电量的消耗。

Optimize Polling with Inexact Repeating Alarms and Exponential Backoffs[通过不定时的重复提醒与指数退避来优化轮询操作]

  • 如果需要使用轮询机制,在不影响用户体验的前提下,当然设置默认更新频率是越低越好[减少电量的浪费]。
  • 一个简单的方法是给用户提供更新频率的选择,允许用户自己来处理如何平衡数据及时性与电量的消耗。
    • 当设置安排好更新操作后,可以使用不确定重复提醒的方式来允许系统把当前这个操作进行定向移动(比如推迟一会)。 
int alarmType = AlarmManager.ELAPSED_REALTIME;  long interval = AlarmManager.INTERVAL_HOUR;  long start = System.currentTimeMillis() + interval;  alarmManager.setInexactRepeating(alarmType, start, interval, pi);
    • 若是多个提醒都被做了“定向移动”,那么很有可能到某个点同时被触发,那么这样就可以使得多个操作在同一个无线电状态下操作完。
    • 如果可以,请设置提醒的类型为ELAPSED_REALTIME or RTC而不是_WAKEUP。这样能够更进一步的减少在等待同时被触发的时候对电量的消耗。
    • 我们还可以通过根据app被使用的频率来有选择性的减少更新的频率。
  • 另一个方法在app在上一次更新操作之后还未被使用的情况下,使用指数退避算法(exponential back-off algorithm)来减少更新频率。当然我们也可以使用一些类似指数退避的方法。
SharedPreferences sp =     context.getSharedPreferences(PREFS, Context.MODE_WORLD_READABLE);    boolean appUsed = sp.getBoolean(PREFS_APPUSED, false);  long updateInterval = sp.getLong(PREFS_INTERVAL, DEFAULT_REFRESH_INTERVAL);    if (!appUsed)    if ((updateInterval *= 2) > MAX_REFRESH_INTERVAL)        updateInterval = MAX_REFRESH_INTERVAL;    Editor spEdit = sp.edit();  spEdit.putBoolean(PREFS_APPUSED, false);  spEdit.putLong(PREFS_INTERVAL, updateInterval);  spEdit.apply();    rescheduleUpdates(updateInterval);  executeUpdateOrPrefetch();
  • 初始化一个网络连接的花费不会因为是否成功下载了数据而改变。我们可以使用指数退避算法来减少重复尝试(retry)的次数,这样能够避免浪费电量。例如:
private void retryIn(long interval) {     boolean success = attemptTransfer();           if (!success) {      retryIn(interval*2 < MAX_RETRY_INTERVAL ?               interval*2 : MAX_RETRY_INTERVAL);           }  }

 

后记:这一课讲到C2DM与指数退避算法等,其实这些细节很值得我们注意,如果能在实际项目中加以应用,很明显质量会比较高。谢谢!
 
学习自:
转载请注明出处:
,谢谢!
你可能感兴趣的文章
java 图片处理
查看>>
博主制作的开源JAVA WEB游戏-《天命.罗生门》
查看>>
Windows软链脚本
查看>>
IOS开发之异步加载网络图片并缓存本地实现瀑布流(二)
查看>>
足球赛事球员信息api
查看>>
那些年我们经历过的运维
查看>>
安装带有调试信息的C库
查看>>
迷宫的基本实现
查看>>
Ajax跨域请求问题
查看>>
topic4:Qt入门之常用qt控件认知之Button系列
查看>>
jstack:Java堆栈跟踪工具
查看>>
源码安装 python3
查看>>
获取当前fragment
查看>>
linux centeros 7.4 修改主机名
查看>>
关于程序员,你知道的有多少?
查看>>
Tomcat问题汇总
查看>>
由于未预料的错误,现在无法使用nautilus
查看>>
业界最有价值的Linux资料大全(200篇)
查看>>
Arraylist动态扩容详解
查看>>
%cd%及%~dp0批处理命令的详解
查看>>