Android SharedReferences在ValueEventListener中放入空值

Android SharedReferences在ValueEventListener中放入空值,android,firebase,firebase-realtime-database,sharedpreferences,event-listener,Android,Firebase,Firebase Realtime Database,Sharedpreferences,Event Listener,我正在尝试在Firebase数据库中查找正确节点的匹配项,并将值保存到SharedReferences。我使用ValueEventListener遍历Firebase中的每个节点。但是,当我试图打印出我刚刚输入到SharedReferences中的值时,所有字段都显示null 我已经通过检查commit()的值来检查是否存在异常,但它返回true 我还认为可能是线程在稍后完成了它的任务,所以我在foreach循环中创建了一个runnable并创建了同步任务。第一个将值保存到SharedRefer

我正在尝试在Firebase数据库中查找正确节点的匹配项,并将值保存到SharedReferences。我使用ValueEventListener遍历Firebase中的每个节点。但是,当我试图打印出我刚刚输入到SharedReferences中的值时,所有字段都显示null

我已经通过检查commit()的值来检查是否存在异常,但它返回true

我还认为可能是线程在稍后完成了它的任务,所以我在foreach循环中创建了一个runnable并创建了同步任务。第一个将值保存到SharedReferences,下一个打印值。但这也不起作用

我还认为上下文不一致可能会有问题,但“SharedRef”和“editor”都使用相同的活动上下文。我在访问其他活动中需要的数据时没有遇到任何问题

这里是我迭代Firebase节点的地方:

final String name = et_name.getText().toString();
DatabaseReference rootref = FirebaseDatabase.getInstance().getReference();
rootref.child("drivers_" + sharedPref.getString("frat_code", null))
    .orderByChild("first_name")
    .addListenerForSingleValueEvent(new ValueEventListener() {
        @Override
        public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
            boolean found = false;
            iterateFirebase:
            for(DataSnapshot node: dataSnapshot.getChildren()) {
                Driver driver = node.getValue(Driver.class);
                if((driver.getName() != null) && (driver.getName().equals(name))) {
                    found = true;
                    editor.putString(driver.getName(), "name");
                    editor.putString(driver.getOccupants(), "occupants");
                    editor.putString(driver.getPhone(), "phone");
                    editor.putString(driver.getMake(), "make");
                    editor.putBoolean("isLogged", true);
                    editor.apply();
                    Log.d(TAG, "Values retrieved from Firebase node: " +
                        driver.getName() + ", " + driver.getOccupants() +
                        ", " + driver.getMake() + ", " +
                        driver.getPhone());
                    Log.i(TAG, "Following user logged in: " +
                        sharedPref.getString("name", null) + ", " +
                        sharedPref.getString("occupants", null) +
                        ", " + sharedPref.getString("phone", null) +
                        ", " + sharedPref.getString("make", null) +
                        ", " + sharedPref.getBoolean("isLogged",
                            false));
                    Intent intent = new Intent(IfYes.this,
                        MainActivity.class);
                    IfYes.this.startActivity(intent);
                    break iterateFirebase;
                }
            }
以下是上述日志语句的日志:

Values retrieved from Firebase node: John Smith, 4, Honda Civic, Black, 
+11234567890
Following user logged in: null, null, null, null, true
提前谢谢你的帮助。此外,我还是一名初学者,因此如果有什么突出的地方,欢迎对任何代码风格的评论。

注意:

editor.putString(driver.getName(), "name");
editor.putString(driver.getOccupants(), "occupants");
editor.putString(driver.getPhone(), "phone");
editor.putString(driver.getMake(), "make");
应该是:

editor.putString("name", driver.getName());
editor.putString("occupants", driver.getOccupants());
editor.putString("phone", driver.getPhone());
editor.putString("make", driver.getMake());