java.lang.IndexOutOfBoundsException: Index: 0, Size: 0当从fire



我在创建一个可以与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实时数据库读取数据?

相关内容

最新更新