我正在使用内容提供商来获取所有联系人,并使用联系人观察器检查此联系人何时已更改,但不能正常工作
@Override
public void onChange(boolean selfChange, Uri uri) {
super.onChange(selfChange, uri);
Log.e("MAS_CHECK", uri + "");
deliverSelfNotifications();
dataBaseAdapter = new DataBaseAdapter(context);
preferences = context.getSharedPreferences("Dtmf app", Context.MODE_PRIVATE);
editor = preferences.edit();
counter = counter + 1;
boolean ExitFromApp = preferences.getBoolean("ExitFromApp", false);
if (counter == 1) {
Log.e("OTD_CHANGE", "there is change");
if (!ExitFromApp) {
final Thread thread = new Thread() {
@Override
public void run() {
Log.e("OTD_CHANGE", "Waiting update to be stable");
try {
sleep(60000);
Log.e("OTD_CHANGE", "update start .. loading new data");
if (dataBaseAdapter.DeletAllItem()) {
ToolsUtils.GetContacts(context);
}
//--------------------------to restart app ----------------
editor.putBoolean("OTD_CHANGE", true);
editor.commit();
counter = 0;
Log.e("OTD_CHANGE", "update finish");
Intent i = new Intent(context, MainActivity.class);
i.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(i);
//-----------------------------------------------------------------
} catch (InterruptedException e) {
e.printStackTrace();
}
}
};
thread.start();
} else if (ExitFromApp) {
counter = 0;
editor.putBoolean("THERE_IS_UPDATE", true);
editor.commit();
}
}
}
**所以我如何使它每次都能稳定运行,这是代码当检测到更改时,应删除数据库中的旧联系人,然后重新添加新数据**
counter
字段可能存在问题,不确定它的行为是否符合您的预期。我建议您从onChange
回调中删除所有代码,而仅添加一个日志,以便您可以检查数据库更改何时以及如何手动调用它。
一旦您更好地了解了它是如何工作的,并且可以开始还原您的代码,我建议不要使用该counter == 1
行。