定时器 - android如何后台运行定时方法
迷茫
迷茫 2017-04-17 11:03:19
[Android讨论组]

应用有个需求,是定时去服务器获取一个账号是否有新的动态。
就像新浪微博那种,打开客户端,会自动提示有多少个 @ 。
我现在想到的方案是这样:

Timer timer = new Timer(); timer.scheduleAtFixedRate(
    new TimerTask() {
        public void run() {
            try {
                checkEvent();
                Thread.sleep(1000);
            } catch (Exception ie) {
            }
        }
    }, 1000, 1000 * 30);

不知道还有没有别的更合理的方案
我这样做会不会有什么风险?
求有经验的大侠分享。。。

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(3)
伊谢尔伦
public class RepeatTaskScheduler extends BroadcastReceiver {

    public static final String ACTION = "com.yourcompanyname.appname.action.RepeatTaskSchedule";

@Override
    public void onReceive(Context context, Intent intent) {
        if (ACTION.equals(action)) {
            checkEvent();
        }
    }
}
//在你想要的地方启动
public class YourActivity extends Activity{
    @Override
    public void onCreate() {
        super.onCreate();
        //如果interval的值太大会失效,几个小时没问题
        setRepeatTasks(1000, 1000 * 30);
    }
    private void setRepeatTasks(long triggerTime, long interval) {
            AlarmManager am = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
        Intent intent = new Intent(RepeatTaskScheduler.ACTION);
        //系统中如果有这个pendingIntent 取消
        PendingIntent pending = PendingIntent.getBroadcast(this, 0, intent,
                PendingIntent.FLAG_NO_CREATE);
        if (pending != null) {
            am.cancel(pending);
        }
        pending = PendingIntent.getBroadcast(this, 0, intent, 0);
        am.setRepeating(AlarmManager.RTC_WAKEUP, triggerTime, interval, pending);
    }
}

在AndroidManifest.xml中加入

<receiver android:name=".RepeatTaskScheduler">
    <intent-filter>
        <action android:name="com.yourcompanyname.appname.action.RepeatTaskSchedule" />
    </intent-filter>
</receiver>

代码我没测试过,只介绍思路,有问题留言

伊谢尔伦

考虑用Handler吧

Handler handler;

 @Override
 public void onCreate(Bundle savedInstanceState) {
     // ...
     handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            updateUI();
        }
    };

    Thread thread = new Thread() {
        @Override
        public void run() {
            while(true) {
                Message msg = new Message();
                handler.sendMessage(msg);
                try {
                    sleep(3*1000); // 3 seconds
                } catch (InterruptedException e) {
                }
            }                       
        }
    };
    thread.start();
 }

 private synchronized void updateUI() {
     // ...
 }
阿神

应该优先使用AlarmManager,Handler比较耗电,而且容易导致内存泄露。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号