7

在 android 中有一些用于刷新处理的选项,例如Timer、TimerTask、ScheduledExecutorService、AlarmManager 和 Handler。这是执行此操作的最佳方法。

有没有人检查上述方法的资源利用率?我在这里列出了上述方法的实现。

使用 Handler 重复执行任务

final Handler handler = new Handler();
handler.postDelayed(new Runnable() {

    public void run() {
        new MyScheduledTask.execute(param);
    }

}, TimeInterval);

使用 Timer 重复执行任务

timer = new Timer();

timer.scheduleAtFixedRate(new TimerTask() {

    synchronized public void run() {
        new MyScheduledTask.execute(param);
        }

}}, 10000, 10000);

使用 ScheduledExecutorService 重复执行任务

ScheduledExecutorService scheduler =
Executors.newSingleThreadScheduledExecutor();
scheduler.scheduleAtFixedRate
  (new Runnable() {
     public void run() {
        new MyScheduledTask.execute(param);
     }
  }, 0, 10, TimeInterval);

使用 Timer 和 TimerTask 重复执行任务

Timer timer = new Timer();
timer.schedule(new UpdateTimeTask(),1, TimeInterval);
class UpdateTimeTask extends TimerTask {

    public void run() 
       {        
        new MyScheduledTask.execute(param);
       }
}

AlarmManager 用于执行计划任务

public void setupTask(){

    // check task is scheduled or not
    boolean alarmUp = (PendingIntent.getBroadcast(this, 0, 
            new Intent("YourPackageHere.AlarmReceiver"), 
            PendingIntent.FLAG_NO_CREATE) != null);

    if (  !alarmUp) {
        Intent intent = new Intent("YourPackageHere.AlarmReceiver");
        intent.putExtra("activate", true);
        PendingIntent pendingIntent =
                    PendingIntent.getBroadcast(this, 0, 
                  intent, PendingIntent.FLAG_UPDATE_CURRENT);

        Calendar calendar = Calendar.getInstance();
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 0);   
        calendar.set(Calendar.MINUTE, 1);
        calendar.set(Calendar.SECOND, 0);

        AlarmManager alarmManager =
                    (AlarmManager)
                    this.getSystemService(this.ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,
                    calendar.getTimeInMillis(), AlarmManager.INTERVAL_DAY,
                    pendingIntent);

        calendar = Calendar.getInstance();
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 7);   
        calendar.set(Calendar.MINUTE, 0);

        alarmManager = (AlarmManager)
                    this.getSystemService(this.ALARM_SERVICE);
        PendingIntent pendingIntent2 =
                    PendingIntent.getBroadcast(this, 1, 
                intent, PendingIntent.FLAG_UPDATE_CURRENT);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,
                    calendar.getTimeInMillis(),
                    AlarmManager.INTERVAL_DAY, pendingIntent2);         

    }

}

报警管理器类

public class AlarmReceiver extends BroadcastReceiver { 

@Override
public void onReceive(Context context, Intent intent) {

    if (intent.hasExtra("activate")) {

        new MyScheduledTask.execute(param);
    }

}
}

显现

<receiver android:name="YourPackageHere.AlarmReceiver"></receiver>
4

2 回答 2

1

为了持续在线,您需要一个Service在线程之上运行的 android。您可以使用您在服务中声明的上述任何方法。

但是,当您制作聊天应用程序时,您必须每 2-3 秒连续访问一次服务器,我认为这对用户不利(就您的应用程序将使用的互联网数据而言)。

用于聊天应用程序的最佳推荐协议是XMPP( Jabber )。它定义了普通聊天应用程序应具备的所有规则,并且非常容易实现。它是一个推送通知类型的服务器,当有新消息到达或添加新朋友时,它会自动向客户端推送通知。(甚至 Gtalk 也使用此协议)

有一个很好的开源服务器提供XMPP名为Openfire的集成,我会推荐它。

同一家公司还提供了一个名为Smack的客户端集成库,您可以在应用程序中轻松实现该库以使用简单的聊天功能。

于 2013-11-04T09:11:58.663 回答
1

处理程序是运行的最佳方法,您可以递归地运行它,这样想会很好......

如果您期望更多,您应该遵循 MQTT 方法,这在消息传递协议中很好

http://mqtt.org/wiki/doku.php/mqtt_on_the_android_platform

于 2013-11-04T09:15:18.870 回答