繁体   English   中英

firebase 数据库到自定义列表视图问题

[英]firebase database to Custom list view problem

如果我做对了,有人能看到吗? 从 firebase 数据库我使用这个获取我的数据


        FirebaseDatabase database = FirebaseDatabase.getInstance();
        database.getReference()
                .child("Users").child("Displayname")
                .addListenerForSingleValueEvent(new ValueEventListener() {
                    @Override
                    public void onDataChange(DataSnapshot dataSnapshot) {
                        for (DataSnapshot snapshot : dataSnapshot.getChildren()){
  Map<String, Object> map =(Map<String, Object>) snapshot.getValue();
                            for (Map.Entry<String, Object> entry : map.entrySet()){

                                Cred = (String) entry.getValue();
                                friend = snapshot.getKey();
     @Override
                    public void onCancelled(DatabaseError databaseError) {

                    }
                });

并使用这个放置到字符串数组

 List<String> list = new ArrayList<String>();
                                list.add(Cred+" "+friend);
                                String[] stringArray = list.toArray(new String[0]);

通过使用下面的代码,我想将其降序排列

 Comparator comparator = new Comparator<String>() {
                                    @Override
                                    public int compare(String o1, String o2) {
                                        String num1 = o1.split(" ")[0];
                                        String num2 = o2.split(" ")[0];
                                        return Integer.parseInt(num2) - Integer.parseInt(num1);
                                    }
                                };
                                Arrays.sort(stringArray, comparator);
                                System.out.println(Arrays.toString(stringArray));

但我没有得到我的结果:

Expected result : 

"300.0 Baul",
"4.0 Alex",
"1.0 Lex B05"

My system print out:

2019-12-23 15:17:02.285 752-752/com.seamans.marina I/System.out: [4.0 Alex]
2019-12-23 15:17:02.292 752-752/com.seamans.marina I/System.out: [300.0 Baul]
2019-12-23 15:17:02.296 752-752/com.seamans.marina I/System.out: [1.0 Lex B05]

我的 Firebase 数据库:

我的 Firebase 数据库

尝试使用这种方式排序

Collections.sort(stringArray, (c1, c2) -> {
    String num1 = c1.split(" ")[0];
    String num2 = c2.split(" ")[0];
    return Double.compare(Double.parseDouble(num2), Double.parseDouble(num1));
});
System.out.println(stringArray);

更新1:用上面替换这个块

 Comparator comparator = new Comparator<String>() {
                                    @Override
                                    public int compare(String o1, String o2) {
                                        String num1 = o1.split(" ")[0];
                                        String num2 = o2.split(" ")[0];
                                        return Integer.parseInt(num2) - Integer.parseInt(num1);
                                    }
                                };
                                Arrays.sort(stringArray, comparator);
                                System.out.println(Arrays.toString(stringArray));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM