テーブル内の特定の属性に対して常にクエリを実行する必要があるアプリを作成しています。現在の方法は次のとおりです。 サービス クラスのコード:
@Override
public int onStartCommand(Intent intent,int flags,int startId)
{
Toast.makeText(this, "Service Started", Toast.LENGTH_LONG).show();
ParseUser currentUser = ParseUser.getCurrentUser();
String username = currentUser.getString("username");
ParseQuery<ParseUser> query = ParseUser.getQuery();
query.whereEqualTo("isAttacking", username);
while(true)
{
query.findInBackground(new FindCallback<ParseUser>() {
public void done(List<ParseUser> objects, ParseException e) {
if ((e == null)&(objects.size() != 0))
{
// The query was successful.
ParseUser attacker = objects.get(0);
String attackerName = attacker.getUsername();
Log.i("ambustest",attackerName);
makeToast(attackerName);
} else {
Log.i("fd","Something went wrong.");
}
}
});
return START_STICKY;
}
}
クエリは無限ループ内にありますが、実行は 1 回だけです。私の推測では、return ステートメントに遭遇したときにクエリが中断する可能性があります。return ステートメントを到達不能なコードに入れずにループを実行し続ける方法はありますか?