我有一个JSONObject,我传递给一个方法来处理ArrayLists
。
{
"set0" :
{
"title" : "Do you win?",
"answer" : "1",
"imgUrl" : "imag",
"id" : "1"
},
"set1" :
{
"title" : "Did you loose?",
"answer" : "1",
"imgUrl" : "imag",
"id" : "2"
}
}
该方法的结构如下:
questions(JSONObject result){
// initialization
for(int i=0;i < result.length();i++){
question_list.add(result.getJSONObject("set"+i).getString("title"));
answer_list.add(result.getJSONObject("set"+i).getString("answer"));
img_list.add(result.getJSONObject("set"+i).getString("imgUrl"));
question_batch.add(result.getJSONObject("set"+i).getInt("id"));
}
// rest of code
}
我通常看到jsonarray用于循环条件,而不是jsonobject本身,当我的jsonobject变大但与上面发布的结构相同时,result.length()
会开始产生错误的结果,这是不正确的希望迭代jsonobject的人的实现?
答案 0 :(得分:0)
你可能也想看看杰克逊。这也非常简单,您的代码可能会从使用它中受益。
答案 1 :(得分:0)
我不确定你的实现是否“不正确”,但这是我通常迭代JSON的方式。
int i = 0;
boolean continue = true;
while (continue){
if (result.has("set" + i){
JSONObject set = result.get("set" + i.toString());
if (set.has("title"){
question_list.add(set.getString("title");
}
if (set.has("answer"){
answer_list.add(set.getString("answer");
}
if (set.has("imgUrl"){
image_list.add(set.getString("imgUrl");
}
if (set.has("id"){
question_batch.add(set.getInt("id");
}
i++;
}else{
continue = false;
}
}
这样效率更高一些,因为每次要将数据拉出时都不必创建新的JSON对象。 此外,我将创建一个新类来处理JSON对象,并创建该类型的数组列表,因此您只需为每次迭代添加一个对象。这样,您可以确保您的问题/答案/ imageURLs / id都保持在一起。像这样:
JSONObject set = result.get("set" + i.toString());
QuestionObject newQuestion = new QuestionObject();
if (set.has("title"){
newQuestion.setTitle(result.getString("title");
}
if (set.has("answer"){
newQuestion.setAnswer(result.getString("answer");
}
if (set.has("imgUrl"){
newQuestion.setImageURL(result.getString("imgUrl");
}
if (set.has("id"){
newQuestion.setID(result.getInt("id");
}
questionList.add(newQuestion);
此外,如果您没有注意到,您可以使用json.getInt()
直接解析整数,而不是字符串。