我在创建一个可以与firebase交互并获取存储在服务器中的信息的应用程序时遇到了问题。但是我在第53行遇到了一些问题。请提供信息,因为我不知道为什么会发生这种情况。当我尝试离线直接提问时,效果完全不错。但是当连接服务器时,每次都失败。
//Line 53
questions = list.get(index);
这是我在QuestionAnsActivity.java中所做的
...
import static com.company.appname.QuizSplash.list;
...
public class QuestionAnsActivity extends AppCompatActivity {
...
List<Questions> allQuestionsList;
Questions questions;
int index = 0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.question_ans_activity);
...
allQuestionsList = list;
Collections.shuffle(allQuestionsList);
// The below code is my line 53
questions = list.get(index);
}}
这是我在QuizSplash.java所做的
public class QuizSplash extends AppCompatActivity {
public static ArrayList<Questions> list;
DatabaseReference databaseReference;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_quiz_splash);
list = new ArrayList<>();
databaseReference = FirebaseDatabase.getInstance().getReference("Question");
databaseReference.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot snapshot) {
for (DataSnapshot dataSnapshot : snapshot.getChildren()) {
Questions questions = dataSnapshot.getValue(Questions.class);
list.add(questions);
}
}
@Override
public void onCancelled(@NonNull DatabaseError error) {
}
});
Intent intent = new Intent(QuizSplash.this, QuestionAnsActivity.class);
startActivity(intent);
}
}
在Questions.java中
public class Questions {
String question;
String option1;
String option2;
String option3;
String option4;
String answer;
//==================================================================================================
// Empty constructor
//==================================================================================================
public Questions() {
}
//==================================================================================================
// Constructor
//==================================================================================================
public Questions(String question, String option1, String option2,
String option3, String option4, String answer) {
this.question = question;
this.option1 = option1;
this.option2 = option2;
this.option3 = option3;
this.option4 = option4;
this.answer = answer;
}
//==================================================================================================
// Getter and setter methods start here
//==================================================================================================
public String getQuestion() {
return question;
}
public void setQuestion(String question) {
this.question = question;
}
public String getOption1() {
return option1;
}
public void setOption1(String option1) {
this.option1 = option1;
}
public String getOption2() {
return option2;
}
public void setOption2(String option2) {
this.option2 = option2;
}
public String getOption3() {
return option3;
}
public void setOption3(String option3) {
this.option3 = option3;
}
public String getOption4() {
return option4;
}
public void setOption4(String option4) {
this.option4 = option4;
}
public String getAnswer() {
return answer;
}
public void setAnswer(String answer) {
this.answer = answer;
}
}
正如我所看到的,您有两个类。在QuizSplash类中,您实际执行数据库调用以获取问题;在QuestionAnsActivity类中,您将来自数据库的结果分配给一个名为allQuestionsList
的现有列表。但是你不应该这样处理实时数据库。
不要忘记数据是从实时数据库异步加载的,这意味着任何需要从数据库加载数据的代码都需要在onDataChange()
方法中,或者从那里调用。所以你不能设置list
对象公共和静态,并简单地在另一个活动中使用它。您需要等待数据完成加载。所以你要么在回调中使用这个列表,要么你可以使用我在以下帖子中的回答:
- 如何返回数据快照值作为一个方法的结果?
我已经解释了如何使用接口传播结果。如果您了解Kotlin,您可能还会对阅读以下文章感兴趣:
- 如何使用get()从Firebase实时数据库读取数据?