Сохранение значения переменных внутри анонимного внутреннего класса

В этой программе я устанавливаю значение одного элемента массива (flag1[0]) равным 1, если выполняется условие «если». Когда я печатаю его (внутри класса), оно показывает значение, установленное как 1. Но когда я пытаюсь получить к нему доступ за пределами внутреннего класса, он показывает значение как 0. Как мне его разрешить? ( getCount() и setCount() являются геттерами и сеттерами, даже они не работают!)

public boolean checkUser(final String user, String program) {

    database = FirebaseDatabase.getInstance();
    final DatabaseReference reference;

    reference = database.getReference("UserNames").child(program);

    final int[] flag1 = {0};
    reference.addValueEventListener(new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {


            for (DataSnapshot data : dataSnapshot.getChildren()) {

                String key = data.getKey();
                Log.println(Log.ERROR,"msg",key);

                if (data.getKey().equals(user))
                {
                    musername.setError("UserName already Exists1!");
                    flag1[0] = 1;
                    setCount(1);
                    Log.println(Log.ERROR,"msg", String.valueOf(flag1[0])+String.valueOf(getCount()));//Shows 1 here

                }
            }

        }

        @Override
        public void onCancelled(DatabaseError databaseError) {

        }
    });

    Log.println(Log.ERROR,"mesg", String.valueOf(flag1[0])+String.valueOf(getCount()));//Shows 0 here
    if(getCount()==0)
        return true;
    return  false;


}

person Atharva Karanje    schedule 27.12.2017    source источник
comment
Весь раздел в вашем внутреннем классе будет выполняться при запуске события.   -  person Juan Carlos Mendoza    schedule 27.12.2017
comment
Да, но как мне это решить? @ХуанКарлосМендоза   -  person Atharva Karanje    schedule 27.12.2017
comment
Код выполняется последовательно, а данные загружаются асинхронно. Это означает, что к моменту выполнения вашего оператора return данные еще не загружены. Решение состоит в том, чтобы либо переместить код, которому нужны данные, в onDataChange() (как показано здесь), либо вызвать оттуда (как показано здесь).   -  person Frank van Puffelen    schedule 27.12.2017


Ответы (1)


Из-за асинхронного поведения метода onDataChange() вы не можете просто использовать эту строку кода:

Log.println(Log.ERROR,"mesg", String.valueOf(flag1[0])+String.valueOf(getCount()));

Вне этого метода, потому что это всегда будет null. Здесь дополнительная информация .

Чтобы решить эту проблему, используйте это значение только внутри этого метода, и ваша проблема будет решена. В противном случае попробуйте понять концепцию асинхронности и посмотрите мой ответ из этого опубликовать

person Alex Mamo    schedule 27.12.2017