问题是JSONArray或多或少拥有最终是字符串的JSONObjects(和其他JSONArrays)。将字符串反序列化为POJO,排序这些,然后回到JSON是相当沉重的。
第二个问题是JSONArray可以包含:Boolean,JSONArray,JSONObject,Number,String或JSONObject.NULL对象;即它是混合类型,使得很难将元素转储到某种类型的列表中并排序,然后通过将排序的项目转储到JSON数组中的列表。从JSONArray获取每个元素的常见类型的唯一一种方法是使用Object get()方法。当然,您所有的都是Object对象,并且无法对它们进行任何有意义的排序,而无需重新访问序列化问题。
假设您的JSONArray包含均匀的结构化值,您可以遍历JSONArray,调用其中一个类型的get()方法,将它们转储为List类型,然后对其进行排序。如果你的JSONArray只是持有“简单”类型,如String或数字,这是比较容易的。这不是确切的代码,但是像:
List jsonValues = new ArrayList();
for (int i = 0; i < myJsonArray.length(); i++)
jsonValues.add(myJsonArray.getString(i));
Collections.sort(jsonValues);
JSONArray sortedJsonArray = new JSONArray(jsonValues);
当然,如果你有嵌套的对象,这可以有点棘手。如果你想排序的价值在最高水平上,那可能不是很糟糕…
List jsonValues = new ArrayList();
for (int i = 0; i < myJsonArray.length(); i++)
jsonValues.add(myJsonArray.getJSONObject(i));
然后使用这样的比较分类:
class JSONComparator implements Comparator
{
public int compare(JSONObject a, JSONObject b)
{
//valA and valB could be any simple type, such as number, string, whatever
String valA = a.get("keyOfValueToSortBy");
String valB = b.get("keyOfValueToSortBy");
return valA.compareTo(valB);
//if your value is numeric:
//if(valA > valB)
// return 1;
//if(valA < valB)
// return -1;
//return 0;
}
}
再次,这就对JSONArray中数据的同质性做了一些假设。如果可能,调整你的情况。另外你还需要添加你的异常处理等。快乐编码!
编辑根据意见修改