- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为什么我会收到此错误?
Caused by: java.lang.IndexOutOfBoundsException: Invalid index 1, size is 0
at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:255)
at java.util.ArrayList.get(ArrayList.java:308)
at com.example.muhammad.exquizme.PlayQuizActivity.displayQuestion(PlayQuizActivity.java:109)
at com.example.muhammad.exquizme.PlayQuizActivity.onCreate(PlayQuizActivity.java:62)
at android.app.Activity.performCreate(Activity.java:6092)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1112)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2481)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2608)
at android.app.ActivityThread.access$800(ActivityThread.java:178)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1470)
at android.os.Handler.dispatchMessage(Handler.java:111)
at android.os.Looper.loop(Looper.java:194)
at android.app.ActivityThread.main(ActivityThread.java:5637)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)
我的手机中已经出现此错误,并且已修复。然后我尝试在平板电脑设备中安装我的应用程序并运行它。当我按下按钮导航到 PlayQuizActivity 时,它崩溃了,并显示Caused by: java.lang.IndexOutOfBoundsException: Invalid index 1, size is 0
。
这是PlayQuizActivity.java的代码:
公共(public)类 PlayQuizActivity 扩展了 AppCompatActivity {
private static final String QUESTION_MANAGER_URL = "http://mbcatubig.net16.net/ExQuiz%20Me/Quiz_Manager.php";
private int randomIndex, questionIndex = 1;
private SQLiteDatabaseHelper questionDatabase;
private RadioButton choiceBtnA, choiceBtnB, choiceBtnC, choiceBtnD;
private TextView questionTextView, qIndexView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_play_quiz);
//questionDatabase = new SQLiteDatabaseHelper(this);
qIndexView = (TextView) findViewById(R.id.currentNumber);
questionTextView = (TextView) findViewById(R.id.questionTextView);
choiceBtnA = (RadioButton) findViewById(R.id.choiceA);
choiceBtnB = (RadioButton) findViewById(R.id.choiceB);
choiceBtnC = (RadioButton) findViewById(R.id.choiceC);
choiceBtnD = (RadioButton) findViewById(R.id.choiceD);
//Get Network State
ConnectivityManager connectivity = (ConnectivityManager) this.getSystemService(Context.CONNECTIVITY_SERVICE);
boolean isConnected = false;
if (connectivity != null) {
NetworkInfo info = connectivity.getActiveNetworkInfo();
if (info != null && info.isConnected()) {
isConnected = true;
}
}
if (isConnected) {
getJSONFromURL();
displayQuestion();
} else {
displayQuestion();
}
choiceBtnA.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkAnswers(0);
}
});
choiceBtnB.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkAnswers(1);
}
});
choiceBtnC.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkAnswers(2);
}
});
choiceBtnD.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkAnswers(3);
}
});
}
private void displayQuestion() {
qIndexView.setText("QUESTION " + questionIndex++ + " /10");
randomIndex = new Random().nextInt(10);
questionDatabase = new SQLiteDatabaseHelper(this);
//Uncheck button
choiceBtnA.setChecked(false);
choiceBtnB.setChecked(false);
choiceBtnC.setChecked(false);
choiceBtnD.setChecked(false);
if (questionIndex <= 10) {
String question = questionDatabase.getQuestions().get(randomIndex).question; //this causes the error
String[] choices = new String[4];
choices[0] = questionDatabase.getQuestions().get(randomIndex).choices[0];
choices[1] = questionDatabase.getQuestions().get(randomIndex).choices[1];
choices[2] = questionDatabase.getQuestions().get(randomIndex).choices[2];
choices[3] = questionDatabase.getQuestions().get(randomIndex).choices[3];
questionTextView.setText(question);
choiceBtnA.setText(choices[0]);
choiceBtnB.setText(choices[1]);
choiceBtnC.setText(choices[2]);
choiceBtnD.setText(choices[3]);
}
}
private void checkAnswers(int index) {
String answer = questionDatabase.getQuestions().get(randomIndex).choices[index], correctAnswer = questionDatabase.getQuestions().get(randomIndex).answer;
if (answer.equals(correctAnswer)) {
Toast.makeText(PlayQuizActivity.this, "Correct", Toast.LENGTH_SHORT).show();
final Handler handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
displayQuestion();
}
}, 2000);
//Log.d("Is it correct?", "Correct");
} else {
Toast.makeText(PlayQuizActivity.this, "Incorrect", Toast.LENGTH_SHORT).show();
final Handler handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
displayQuestion();
}
}, 2000);
//Log.d("Is it correct?", "Incorrect");
}
}
private void getJSONFromURL() {
class QuestionExtractorTask extends AsyncTask<Void, Void, String> {
ProgressDialog loading;
@Override
protected void onPreExecute() {
super.onPreExecute();
loading = ProgressDialog.show(PlayQuizActivity.this, "Loading questions...", null, true, true);
}
@Override
protected String doInBackground(Void... params) {
BufferedReader bufferedReader;
try {
URL url = new URL(QUESTION_MANAGER_URL);
HttpURLConnection con = (HttpURLConnection) url.openConnection();
StringBuilder sb = new StringBuilder();
bufferedReader = new BufferedReader(new InputStreamReader(con.getInputStream()));
String json;
while ((json = bufferedReader.readLine()) != null) {
sb.append(json + "\n");
}
json = sb.toString().trim();
return json;
} catch (Exception e) {
return null;
}
}
@Override
protected void onPostExecute(String jsonData) {
super.onPostExecute(jsonData);
loading.dismiss();
QuestionJSONParser questionJsonParser = new QuestionJSONParser();
questionJsonParser.extractJSON(jsonData);
}
}
QuestionExtractorTask questionExtractorTask = new QuestionExtractorTask();
questionExtractorTask.execute();
}
class QuestionJSONParser {
private static final String ROOT_OBJECT = "questions", QUESTION = "question", CHOICES = "choices", CATEGORY = "category";
public void extractJSON(String jsonData) {
try {
//Get the questions object
JSONObject questions = new JSONObject(jsonData).getJSONObject(ROOT_OBJECT);
//Get the questions' objects
Collections.shuffle(uniqueRandomNumber(questions.length()));
for (int counter = 0; counter < 10; counter++) {
String[] choices = new String[4];
System.out.println(uniqueRandomNumber(questions.length()));
JSONObject theQuestionObject = questions.getJSONObject(uniqueRandomNumber(questions.length()).get(counter) + "");
String question = theQuestionObject.getString(QUESTION), category = theQuestionObject.getString(CATEGORY), correctAnswer = "";
//Log.d("question", question);
JSONArray theChoicesArray = theQuestionObject.getJSONArray(CHOICES);
//Get choice object from the choices object
for (int i = 0; i < theChoicesArray.length(); i++) {
JSONObject choiceObject = theChoicesArray.getJSONObject(i);
choices[i] = choiceObject.optString("choice");
if (choiceObject.getInt("is_correct_choice") == 1) {
correctAnswer = choices[i];
}
}
//add in SQLite Database
questionDatabase = new SQLiteDatabaseHelper(getApplicationContext());
questionDatabase.addQuestion(new QuizQuestion(question, choices, correctAnswer, category));
}
} catch (JSONException e) {
e.printStackTrace();
}
}
public List uniqueRandomNumber(int length) {
if (length != 0) {
Integer[] arr = new Integer[length];
for (int i = 0; i < arr.length; i++) {
arr[i] = i + 1;
}
return Arrays.asList(arr);
}
return null;
}
}
}
我正在尝试找出解决此问题的方法。我考虑过一些导致错误的可能性。我想当从 url 中提取 json 然后解析它时,也许它不会将这些数据保存到我的 sqlite 数据库中,但这个问题已经解决了,所以我不知道这是如何发生的。它总是说尺寸是0。这是否意味着我需要坚持使用我的手机。我想这与sdk版本无关,不是吗?
这是我的SQLiteDatabaseHelper.class:
类 SQLiteDatabaseHelper 扩展 SQLiteOpenHelper {
private static final String[] TABLES = new String[]{"question", "question_choices", "stats"};
public SQLiteDatabaseHelper(Context context) {
super(context, "QUESTION_DATABASE", null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
//Create Questions Table
String CREATE_QUESTIONS_TABLE = "CREATE TABLE " + TABLES[0] + " (\n" +
" quiz_question_id INT PRIMARY KEY,\n" +
" question TEXT ,\n" +
" choice_a TEXT,\n" +
" choice_b TEXT ,\n" +
" choice_c TEXT ,\n" +
" choice_d TEXT ,\n" +
" answer TEXT ,\n" +
" category TEXT)";
db.execSQL(CREATE_QUESTIONS_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS" + TABLES[0]);
db.execSQL("DROP TABLE IF EXISTS" + TABLES[2]);
}
//Managing question for the quiz
public void addQuestion(QuizQuestion questions) {
SQLiteDatabase db = this.getWritableDatabase();
//Insert in question table
ContentValues values = new ContentValues();
values.put("question", questions.question);
values.put("choice_a", questions.choices[0]);
values.put("choice_b", questions.choices[1]);
values.put("choice_c", questions.choices[2]);
values.put("choice_d", questions.choices[3]);
values.put("answer", questions.answer);
values.put("category", questions.category);
// Inserting Row
db.insert(TABLES[0], null, values);
db.close(); // Closing database connection
}
//Managing best scores and best category for stats
public List<QuizQuestion> getQuestions() {
List<QuizQuestion> quizQuestionArrayList = new ArrayList<>();
String selectQuery = "SELECT * FROM " + TABLES[0];
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
if (!cursor.isLast()) {
while (cursor.moveToNext()) {
//Log.d("cursor.getString(1)", cursor.getString(1));
String[] choices = {cursor.getString(2), cursor.getString(3), cursor.getString(4), cursor.getString(5)};
quizQuestionArrayList.add(new QuizQuestion(cursor.getString(1), choices, cursor.getString(6), cursor.getString(7)));
}
}
db.close();
return quizQuestionArrayList;
}
}
上面的代码处理 sqlite 数据库。如果我连接到互联网,我基本上想要在这里完成的任务是,它会将数据下载到我的 sqlite 数据库中,这样当它离线时,就可以访问它。我的手机上已经发生过这种情况,但在我的平板电脑上,它无法正常工作,如上面的错误所示。如果您需要更多详细信息,请告诉我。任何帮助表示赞赏。谢谢。
最佳答案
在我看来,你的数据库是空的。数据库助手的 onCreate 创建了一个表,但它从不向其中添加任何内容。
您的网络代码也不正确 - 您调用
getJSONFromURL();
displayQuestion();
但是 getJsonFromUrl 启动了一个异步任务。您不希望在任务完成之前调用 displayQuestion。 displayQuestion 只能在 onPostExecute 中调用,或者在过去下载过数据的情况下调用。
关于java - 为什么将我的应用程序安装到其他设备后会出现 IndexOutOfBoundsException?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36854043/
iphone设备UDID、iphone设备ID和iphone设备Token之间有什么区别? 通常,当我们使用苹果推送通知服务时,会使用 iPhone 设备 token 。 但我的目标只是识别唯一的 i
我们使用 firebase 从服务器向 Android 和 IOS 设备发送通知,并且我们使用旧版 FCM 发送通知。但是当我们的应用程序在后台时,通知由系统本身处理,因此我们无法通过应用程序处理它。
在 Google 上搜索后,我发现人们说只能通过“MFi 程序”将 iOS 设备与非 iOS 设备连接起来。这是真的吗? 我的项目主要集中于直接通过蓝牙与Arduino设备发送和接收信息。 iOS和非
所以我有一个通用应用程序,我正在设置 UIScrollView 的内容大小。显然,iPhone 和 iPad 上的内容大小会有所不同。如何为 iPad 设置某种尺寸,为 iPhone 和 iPod t
问题:如何在 pod 中使用连接到主机的原始设备作为 block 设备。 我尝试使用类型为“BlockDevice”的“hostPath” volumes: - my-data: hostPath
Implemented GCKDeviceScannerListener Singleton Class on ViewController, however its delegate methods
我有一个 (PhoneGap) 应用程序,它将成功获得 Passbook 通行证,并且还将成功接收与 Passbook 分开的推送通知(当伪造设备 ID 时)。 我遇到的问题是发送给注册设备的设备 I
我正在尝试找到一种方法,通过我目前正在使用的 iOS 应用程序访问我的信标的电池电量。我正在使用 Kontakt 的 iBeacon 设备。我浏览了 Estimote iOS SDK,他们提供了一种实
我正在努力让 CUDA 应用程序也能监控 GPU 的核心温度。可通过 NVAPI 访问该信息。 问题是我想确保在运行代码时监控的是同一个 GPU。 但是,似乎有信息表明我从 NvAPI_EnumPhy
从沙箱模式到生产模式,设备 token 有何不同? 我认为我已将一些设备 token 锁定为生产模式,并且无法将它们从开发中插入。 关于如何检查有什么想法吗? 最佳答案 当您使用开发证书构建应用程序时
目录 /run/user/1000/gvfs 和 ~/.gvfs 分别是空的和不存在的。我的图形文件管理器 (Thunar) 能够检测和访问设备的内部和外部存储器。 命令 gvfs-mount -l
我有一个 Android 平板电脑,它有一个迷你 USB 端口和一个 USB 端口,我想编写一个与 USB key 通信的应用程序。我写了一个demo来找出U盘,但是没有任何反应。 令我不安的是,如果
我们将 PHP 版本从 5.4.25 更改为 5.4.45,并在服务器上安装了 MS SQL 驱动程序。在更改服务器之前,一切正常,但在更改服务器之后,我遇到了 Web 服务问题。我们的身份验证 So
我想知道是否有人使用此 API 在 Android 设备上同时从 2 个后置摄像头捕获图像或视频:https://source.android.com/docs/core/camera/concurr
我正在为客户构建一个物联网解决方案,网络管理员坚持要求设备仅通过访客网络进行连接,该网络有一个强制门户,其中的服务条款必须通过按下 UI 按钮来接受,然后才能获得外部互联网访问。到目前为止,我见过的大
我无法弄清楚这里的格式规则..在我的示例中,代码行太多,无法为每行添加 4 个空格,因此这里是我需要帮助的代码的链接 http://nitemsg.blogspot.com/2011/01/heres
如果我在我的设备上接受推送通知,并且不保存设备 token ,那么我如何在自定义 View 中查看设备 token 或恢复警报 View ? 我删除了应用程序并重新安装,但看不到设备 token 警报
我试图找出在尝试并行比较和复制设备 block 与 pthreads 时我做错了什么。看起来我正在脱离同步并且比较阶段无法正常工作。任何帮助将不胜感激 #ifndef __dbg_h__ #defin
我刚刚写完所有这些内容,但这个红色的小栏告诉我我不能发布图片或两个以上的链接。因此,如果您可以引用 this Imgur album , 那简直太好了。谢谢。 我在这里相对较新,甚至对 android
我需要启用 mysql 常规日志并将其通过 nsf 移动到我系统中的另一个驱动器/设备! 所以,我在 my.cnf 中启用了它: general_log = 1 general_log_fi
我是一名优秀的程序员,十分优秀!