Android 为什么我不能在ListView中显示Firebase数据

Android 为什么我不能在ListView中显示Firebase数据,android,listview,firebase,firebase-realtime-database,Android,Listview,Firebase,Firebase Realtime Database,有人能帮我解决这个问题吗?我试图在Listview中显示firebase中的作业,但它什么都不显示!我在堆栈和不同站点尝试了不同的主题代码,但在 adapter=new ArrayAdapter<String> (this,android.R.layout.simple_list_item_1,retrieve()); 无一例外 Java代码 使用文本视图 当我使用文本视图时,数据只显示一个atmost // Adding click listener to Show data b

有人能帮我解决这个问题吗?我试图在Listview中显示firebase中的作业,但它什么都不显示!我在堆栈和不同站点尝试了不同的主题代码,但在

adapter=new ArrayAdapter<String>
(this,android.R.layout.simple_list_item_1,retrieve());
无一例外

Java代码

使用文本视图

当我使用文本视图时,数据只显示一个atmost

// Adding click listener to Show data button.
    ShowButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

            // Adding addValueEventListener method on firebase object.
            firebase.addValueEventListener(new ValueEventListener() {
                @Override
                public void onDataChange(DataSnapshot MainSnapshot) {

              for (DataSnapshot SubSnapshot : MainSnapshot.getChildren()) {

              JobDetails jobdetails =SubSnapshot.getValue(JobDetails.class);
                    for
                        // Adding name and phone number of student into 
                      string that is coming from server.

                        String ShowDataString = "Job: " + 
                        jobdetails.getjob() + "\nJob Description: " + 
                        jobdetails.getjobDescription() + "\n\n";

                        // Apply complete string variable into TextView.
                        ShowDataTextView.setText(ShowDataString);
               }
                    }
                }

                @Override
                public void onCancelled(FirebaseError firebaseError) {
                    System.out.println("Data Access Failed" + 
                firebaseError.getMessage());
                }
            });
        }
        });
使用Xml

java错误行

它在这一点上显示错误

 lv.setAdapter(arrayAdapter);

代码中的问题是retrieve,这是一个返回名为spacecrafts的ArrayList的方法。此ArrayList在代码的第一行中初始化,但从未更新。换句话说,你在你的适配器中使用的是空的太空飞船


为了解决这个问题,每次从Firebase获取数据时,都将其添加到正确的ArrayList中。对于node,还有一件事,由于这些方法的异步行为,您不能以您的方式返回ArrayList,因为它总是空的。您需要在该方法中声明并使用/更新该ArrayList。

问题是,您填充数据太早了。当您调用retrieve方法时,它会立即运行并返回一个空的Arrylist。Firebase不会立即向您提供数据。它在获取数据时会造成一些延迟。因此,首先获取所有数据,然后填充适配器

或使用

adapter.notifydatasetchanged(); 

获取数据后。

您是否设法用字符串填充ArrayList?要使用正确的答案?我更新了问题!当我使用文本视图时,它工作得很好,但只显示第一行值。这大约需要5-10秒。很高兴听到它工作了。尝试使用Log.dTAG,ShowDataString;。是否显示所有值?日志显示所有数据,文本视图仅显示logcat中的最后一个值。我该怎么办?任何建议!
 public class JobDetails {

    private String price;
    private String jobDescription;
    private String jobSpinner;
    public String email;
    public JobDetails() {
        // This is default constructor.
    }

    public String getPrice() {

        return price;
    }

    public void setPrice(String pri) {

        this.price = pri;
    }

    public String getjobDescription() {

        return jobDescription;

    }

    public void setjobDescription(String jobd) {

        this.jobDescription = jobd;
    }

    public void setjob(String jry) {

        this.jobSpinner = jry ;

    }

    public String getjob() {

        return jobSpinner;

    }

    public void setemail(String jel) {

        this.email = jel ;

    }

    public String getemail() {

        return email;

    }
}
// Adding click listener to Show data button.
    ShowButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

            // Adding addValueEventListener method on firebase object.
            firebase.addValueEventListener(new ValueEventListener() {
                @Override
                public void onDataChange(DataSnapshot MainSnapshot) {

              for (DataSnapshot SubSnapshot : MainSnapshot.getChildren()) {

              JobDetails jobdetails =SubSnapshot.getValue(JobDetails.class);
                    for
                        // Adding name and phone number of student into 
                      string that is coming from server.

                        String ShowDataString = "Job: " + 
                        jobdetails.getjob() + "\nJob Description: " + 
                        jobdetails.getjobDescription() + "\n\n";

                        // Apply complete string variable into TextView.
                        ShowDataTextView.setText(ShowDataString);
               }
                    }
                }

                @Override
                public void onCancelled(FirebaseError firebaseError) {
                    System.out.println("Data Access Failed" + 
                firebaseError.getMessage());
                }
            });
        }
        });
   <TextView
    android:id="@+id/showmetadata"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@id/show"
    android:textSize="40sp"
    android:textAlignment="center"/>
 public class WorkActivity extends AppCompatActivity {

//    Spinner jobSpin;

ListView lv;
Button ShowButton;
// Define a String ArrayList for the job
private ArrayList<String> jobdes=new ArrayList<>();

// Define an ArrayAdapter for the list
private ArrayAdapter<String> arrayAdapter;

// Declaring String variable ( In which we are storing firebase server URL 
).
public static final String Firebase_Server_URL = 
"https://jobaps70.firebaseio.com/";
public static final String Firebase_Server_URL1 = 
 "https://jobaps70.firebaseio.com/jobs";

// Declaring String variables to store name & phone number get from 
EditText.
String PriceHolder, JobDescriptionHolder;
FirebaseHelper helper;

// Declaring Firebase object.
Firebase firebase,firebase1;

// Creating FirebaseAuth.
FirebaseAuth firebaseAuth ;

// Creating FirebaseAuth.
FirebaseUser firebaseUser;

// Creating Boolean variable that holds EditText is empty or not status.
Boolean EditTextStatus ;


TextView ShowDataTextView ;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_edits_jobs);

      //        Actionbar
    getSupportActionBar().setDisplayShowHomeEnabled(true);
    getSupportActionBar().setIcon(R.drawable.logo);
    getSupportActionBar().setBackgroundDrawable(new 
    ColorDrawable(getResources().getColor(R.color.Snow)));

    ShowButton = (Button)findViewById(R.id.show);

    // Adding MainActivity context into Firebase context.
    Firebase.setAndroidContext(WorkActivity.this);

    // Passing firebase Server URL into firebase object.
    firebase = new Firebase(Firebase_Server_URL);
    firebase1=new Firebase(Firebase_Server_URL1);

    firebaseAuth = FirebaseAuth.getInstance();

    // On activity start check whether there is user previously logged in or 
       not.
    if(firebaseAuth.getCurrentUser() == null){

        // Finishing current Profile activity.
        finish();

        // If user already not log in then Redirect to LoginActivity .
        Intent intent = new Intent(WorkActivity.this, LoginActivity.class);
        startActivity(intent);

        // Showing toast message.
        Toast.makeText(WorkActivity.this, "Please Log in to continue", 
        Toast.LENGTH_LONG).show();

    }

    // Adding firebaseAuth current user info into firebaseUser object.
    firebaseUser = firebaseAuth.getCurrentUser();

    // Getting logged in user email from firebaseUser.getEmail() method and 
        set into TextView.
    setTitle( firebaseUser.getEmail());
    setTitleColor(R.color.DarkGray);
      firebase.child("jobs");

    // Associate the jobs' list with the corresponding ListView
    lv = (ListView) findViewById(R.id.lvshow);

    // Set the ArrayAdapter to the ListView
    arrayAdapter = new ArrayAdapter<String>(this, 
       android.R.layout.simple_list_item_1, jobdes);
    lv.setAdapter(arrayAdapter);

    // Attach a ChildEventListener to the teacher database, so we can 
          retrieve the job entries
    firebase.addChildEventListener(new ChildEventListener() {
        @Override
        public void onChildAdded(DataSnapshot dataSnapshot, String s) {

            // Get the value from the DataSnapshot and add it to the jobs' 
         list
            JobDetails jo = (JobDetails) 
         dataSnapshot.getValue(JobDetails.class);
            String joString = String.valueOf(jo);
            arrayAdapter.add(joString);
 //

            // Notify the ArrayAdapter that there was a change
            arrayAdapter.notifyDataSetChanged();
        }

        @Override
        public void onChildChanged(DataSnapshot dataSnapshot, String s) {

        }

        @Override
        public void onChildRemoved(DataSnapshot dataSnapshot) {

        }

        @Override
        public void onChildMoved(DataSnapshot dataSnapshot, String s) {

        }

        @Override
        public void onCancelled(FirebaseError databaseError) {

        }
    });
}

}
E/AndroidRuntime: FATAL EXCEPTION: main
              Process: com.gumption.zeeshanahmed.jobaps, PID: 4774
              java.lang.RuntimeException: Unable to start activity 
              ComponentInfo{com.gumption.zeeshanahmed.jobaps/
              com.gumption.zeeshanahmed.jobaps.WorkActivity}: 
              java.lang.NullPointerException: Attempt to invoke virtual 
              method 'void 
             android.widget.ListView.setAdapter(android.widget.ListAdapter)' 
             on a null object reference at 
  android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
                  at android.app.ActivityThread.-wrap11(ActivityThread.java)
                  at 
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
                  at android.os.Handler.dispatchMessage(Handler.java:102)
                  at android.os.Looper.loop(Looper.java:148)at 
 android.app.ActivityThread.main(ActivityThread.java:5417)
                  at java.lang.reflect.Method.invoke(Native Method) at 
 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run
 (ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main 
 (ZygoteInit.java:616) 
 Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 
 'void android.widget.ListView.setAdapter(android.widget.ListAdapter)' on a 
 null object reference at 
 com.gumption.zeeshanahmed.jobaps.WorkActivity.onCreate
 (WorkActivity.java:109)
              at android.app.Activity.performCreate(Activity.java:6237) at 
 android.app.Instrumentation.callActivityOnCreate
 (Instrumentation.java:1107) at 
 android.app.ActivityThread.performLaunchActivity
 (ActivityThread.java:2369)atandroid.app.ActivityThread.handleLaunchActivity
 (ActivityThread.java:2476) at android.app.ActivityThread.-
  wrap11(ActivityThread.java) at android.app.ActivityThread$H.handleMessage
 (ActivityThread.java:1344) at android.os.Handler.dispatchMessage
 (Handler.java:102) at android.os.Looper.loop(Looper.java:148) at 
 android.app.ActivityThread.main(ActivityThread.java:5417) at 
 java.lang.reflect.Method.invoke(Native Method) at 
 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run
 (ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main
 (ZygoteInit.java:616) 
 lv.setAdapter(arrayAdapter);
adapter.notifydatasetchanged();