SharedPreferences продолжают удаляться перед использованием - PullRequest
0 голосов
/ 02 февраля 2020

Это doos ie. Я храню значения int в моих общих префиксах, по сути кэшируя их, чтобы при следующем запуске я мог поместить их в БД. У меня есть метод для сохранения их в БД при запуске.

Затем следует метод для удаления значений из общих префов для их сброса.

Но они, похоже, продолжают удалять до Я могу хранить их в БД. Это похоже на deleteMetrics(); до setMetrics(); независимо от того, что я делаю.

  • Я попытался поместить удаление общих значений pref в свой собственный метод в Activity запуска.
  • Я попытался поместить удаление общих значений pref в метод setMetrics при запуске Activity.
  • Я попытался поместить удаление общих значений pref в разные места в onCreate для операции запуска.
  • Я попытался поместить удаление общих значений pref в класс Metrics как внутри, так и вне метода startupUpdateMetrics().
  • Я попытался поместить удаление общих значений pref в runOnUiThread в случае, если у меня есть утечка потока (см. ниже).
  • Я пробовал Thread.sleep (5000) в onCreate для запуска действия между settMetrics(); и deleteMetrics();

Ничего не работает. Значения удаляются до того, как метод setMetrics(); сохранит их в БД.

Если я закомментирую deleteMetrics();, значения БД сохранятся в порядке, но они растут экспоненциально, потому что sharedPrefs не сбрасываются для каждого использование приложения.

Активность запуска onCreate:

Activity_Splash.this.runOnUiThread(new Runnable() {
    @Override
    public void run() {
        setMetrics();
        deleteMetrics();
    }
});

setMetrics (); и deleteMetrics ();

private void setMetrics() {
    SharedPreferences sharedPreferences = Activity_Splash.this.getSharedPreferences("com.dmurphy.remotescrumpoker", Context.MODE_PRIVATE);
    //Check if device has a network connection
    boolean connectionExists = new NetworkConnection().haveNetworkConnection(passedActivity, TAG);

    //If device has a network connection continue
    if (connectionExists) {
        Log.i(" => ", "Test1");
        try {
            String userId = mAuth.getCurrentUser().getUid();
            int teamCreated2 = sharedPreferences.getInt("teamCreatedForMetrics", 0);
            Log.i(" => ", "Test2 " + teamCreated2);
            callMetrics.startupUpdateMetrics(userId, context);
        } catch (Exception e) {
            Log.e(TAG + "onCreate", "Error setting metrics");
        }
    }
}

private void deleteMetrics() {
    SharedPreferences sharedPreferences = Activity_Splash.this.getSharedPreferences("com.dmurphy.remotescrumpoker", Context.MODE_PRIVATE);
        try {
            sharedPreferences.edit().remove("acceptedForMetrics").commit();
            sharedPreferences.edit().remove("rejectedForMetrics").commit();
            sharedPreferences.edit().remove("requestedForMetrics").commit();
            sharedPreferences.edit().remove("sm2AppointedForMetrics").commit();
            sharedPreferences.edit().remove("teamCreatedForMetrics").commit();
            sharedPreferences.edit().remove("teamDeletedForMetrics").commit();
            sharedPreferences.edit().remove("noOfPlayersForMetrics").commit();
            sharedPreferences.edit().remove("teamsMemberLeaveForMetrics").commit();
        } catch (Exception e) {
            Log.e(TAG + "onCreate", "Error setting metrics");
        }
    }

callMetrics, вызываемый методом setMetrics:

public void startupUpdateMetrics(String userId, Context context) {
    SharedPreferences sharedPreferences = context.getSharedPreferences("com.dmurphy.remotescrumpoker", Context.MODE_PRIVATE);

    db.collection("userteammetrics").document(userId).collection("teammetrics").document("generalteammetrics").get().addOnCompleteListener(new OnCompleteListener<DocumentSnapshot>() {
        @Override
        public void onComplete(@NonNull Task<DocumentSnapshot> task) {
            if (task.isSuccessful()) {
                int teamCreated4 = sharedPreferences.getInt("teamCreatedForMetrics",0);
                Log.i(" => ", "Test4 " + teamCreated4);
                DocumentSnapshot document = task.getResult();

                if (document.exists()) {
                    int teamCreated5 = sharedPreferences.getInt("teamCreatedForMetrics",0);
                    Log.i(" => ", "Test5 " + teamCreated5);
                    int oldAccepted = Integer.parseInt(document.get("accepted").toString());
                    int oldRejected = Integer.parseInt(document.get("rejected").toString());
                    int oldRequested = Integer.parseInt(document.get("requested").toString());
                    int oldsm2Appointed = Integer.parseInt(document.get("scrummaster2sappointed").toString());
                    int oldTeamsCreated = Integer.parseInt(document.get("teamscreated").toString());
                    int oldTeamsDeleted = Integer.parseInt(document.get("teamsdeleted").toString());
                    int oldTeamsMemberLeave = Integer.parseInt(document.get("memberLeave").toString());

                    int addAccepted = sharedPreferences.getInt("acceptedForMetrics",0);
                    int addRejected = sharedPreferences.getInt("rejectedForMetrics",0);
                    int addRequested = sharedPreferences.getInt("requestedForMetrics",0);
                    int addsm2Appointed = sharedPreferences.getInt("sm2AppointedForMetrics",0);
                    int addTeamsCreated = sharedPreferences.getInt("teamCreatedForMetrics",0);
                    int addTeamsDeleted = sharedPreferences.getInt("teamDeletedForMetrics",0);
                    int playersPerGame = sharedPreferences.getInt("noOfPlayersForMetrics",0);
                    int addTeamsMemberLeave = sharedPreferences.getInt("teamsMemberLeaveForMetrics",0);
                    Log.i("Test6 ", "startupUpdateMetrics: " + addAccepted + " " + addRejected + " " + addRequested + " " + addsm2Appointed + " " + addTeamsCreated + " " + addTeamsDeleted + " " + playersPerGame + " " + addTeamsMemberLeave);

                    int newAccepted = oldAccepted + addAccepted;
                    int newRejected = oldRejected + addRejected;
                    int newRequested = oldRequested + addRequested;
                    int newsm2Appointed = oldsm2Appointed + addsm2Appointed;
                    int newTeamsCreated = oldTeamsCreated + addTeamsCreated;
                    int newTeamsDeleted = oldTeamsDeleted + addTeamsDeleted;
                    int newTeamsMemberLeave = oldTeamsMemberLeave + addTeamsMemberLeave;
                    Log.i("Test7  ", "startupUpdateMetrics: " + newAccepted + " " + newRejected + " " + newRequested + " " + newsm2Appointed + " " + newTeamsCreated + " " + newTeamsDeleted + " " + newTeamsMemberLeave);

                    db.collection("userteammetrics").document(userId).collection("teammetrics").document("generalteammetrics").update("accepted", newAccepted, "rejected", newRejected, "requested", newRequested, "scrummaster2sappointed", newsm2Appointed, "teamscreated", newTeamsCreated, "teamsdeleted", newTeamsDeleted, "memberLeave", newTeamsMemberLeave, "numberofplayerspergame" ,FieldValue.arrayUnion(playersPerGame));

                }
            }
        }
    });
}

LogCat (я не знаю, почему все это появляется дважды ... поэтому я думал, что там может быть дырявая нить):

2020-02-01 23:19:28.954 21586-21586/? I/Ads: Use RequestConfiguration.Builder().setTestDeviceIds(Arrays.asList("xxxxxxxxxxxxx") to get test ads on this device.
2020-02-01 23:19:29.026 21586-21586/? I/Ads: Use RequestConfiguration.Builder().setTestDeviceIds(Arrays.asList("xxxxxxxxxxxxx") to get test ads on this device.
2020-02-01 23:19:29.078 21586-21586/? I/ =>: Test1
2020-02-01 23:19:29.078 21586-21586/? I/ =>: Test2 0
2020-02-01 23:19:29.085 21586-21586/? I/ =>: Test1
2020-02-01 23:19:29.085 21586-21586/? I/ =>: Test2 0
2020-02-01 23:19:29.207 21586-21586/? I/Ads: Use RequestConfiguration.Builder().setTestDeviceIds(Arrays.asList("xxxxxxxxxxxxx") to get test ads on this device.
2020-02-01 23:19:29.219 21586-21586/? I/Ads: Use RequestConfiguration.Builder().setTestDeviceIds(Arrays.asList("xxxxxxxxxxxxx") to get test ads on this device.
2020-02-01 23:19:29.344 21586-21586/? I/ =>: Test4 0
2020-02-01 23:19:29.344 21586-21586/? I/ =>: Test5 0
2020-02-01 23:19:29.345 21586-21586/? I/Test6: startupUpdateMetrics: 0 0 0 0 0 0 0 0
2020-02-01 23:19:29.345 21586-21586/? I/Test7: startupUpdateMetrics: 0 0 0 0 0 0 0
2020-02-01 23:19:29.345 21586-21586/? I/ =>: Test4 0
2020-02-01 23:19:29.346 21586-21586/? I/ =>: Test5 0
2020-02-01 23:19:29.346 21586-21586/? I/Test6: startupUpdateMetrics: 0 0 0 0 0 0 0 0
2020-02-01 23:19:29.346 21586-21586/? I/Test7: startupUpdateMetrics: 0 0 0 0 0 0 0
2020-02-01 23:21:04.323 21908-21927/? I/PrimesTesting: GserviceFlagsSupplier.get()
2020-02-01 23:22:40.049 22041-22041/? D/OmtpVvmCarrierCfgHlpr: overrideConfigForTest is null

Я в недоумении с этим, любой совет будет высоко ценится.

Ответы [ 2 ]

1 голос
/ 02 февраля 2020

Вы можете попытаться настроить таймер для непрерывной проверки того, завершил ли setMetrics() весь свой код, чтобы метод deleteMetrics() запускался после.

private static boolean done = false;

Activity_Splash.this.runOnUiThread(new Runnable() {
    @Override
    public void run() {
        setMetrics();
        final Timer t=new Timer();
        t.schedule(new TimerTask() {
        @Override
        public void run() {
        if(done){
        deleteMetrics();
        t.cancel();
        t.purge();
        }
        }
     }, 1000);

    }
});

Назначьте логическое значение * От 1006 * до true в конце setMetrics().

 private void setMetrics() {
        SharedPreferences sharedPreferences = Activity_Splash.this.getSharedPreferences("com.dmurphy.remotescrumpoker", Context.MODE_PRIVATE);
        //Check if device has a network connection
        boolean connectionExists = new NetworkConnection().haveNetworkConnection(passedActivity, TAG);

        //If device has a network connection continue
        if (connectionExists) {
            Log.i(" => ", "Test1");
            try {
                String userId = mAuth.getCurrentUser().getUid();
                int teamCreated2 = sharedPreferences.getInt("teamCreatedForMetrics", 0);
                Log.i(" => ", "Test2 " + teamCreated2);
                callMetrics.startupUpdateMetrics(userId, context);
                done=true;
            } catch (Exception e) {
                Log.e(TAG + "onCreate", "Error setting metrics");
            }
        }
    }
1 голос
/ 02 февраля 2020

Вот что происходит:

setMetrics() вызывается первым
setMetrics() звонками startupUpdateMetrics()
startupUpdateMetrics() звонками db.collection... с обратным вызовом (параметр в addOnCompleteListener call)
deleteMetrics() называется

обратный вызов выполняется асинхронно.

Таким образом, вы запускаете асинхронную задачу, а затем сразу после запуска этой задачи (но еще не завершенной), Вы удаляете все свои данные.

Вам нужно дождаться обратного вызова, а затем вы можете удалить свои данные.

Поместите deleteMetrics() в качестве последней строки в скобках if (document.exists()).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...