原文出自:https://blog.csdn.net/seesun2012

简介如题:Java如何操作对象(bean)进行动态排序?Java实体类(bean)动态排序?


原理:利用反射根据指定的属性值排序

技巧:利用Collections组件的ComparatorUtils类可以实现含有空值的排序,请读者参考相关的API


(1)编写Student类,该类定义了3个域:id,name,score,并且提供了相应的get和set方法。代码如下:

package com.seesun2012.test;
import java.io.Serializable; /**
* 学生类
*
* @author seesun2012@163.com
*
*/
public class Student implements Serializable{ private static final long serialVersionUID = -2551164688062992567L; private int id; //编号
private String name; //姓名
private double score; //分数 public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public double getScore() {
return score;
}
public void setScore(double score) {
this.score = score;
} @Override
public String toString() {
return "学生编号:" + id + ",学生姓名:" + name + ",分数:" + score;
} }

(2)编写测试类,在该类的main()方法中创建了3个Student对象并进行初始化,然后使用score域进行排序。代码如下:

package com.seesun2012.test;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import org.apache.commons.beanutils.BeanComparator; /**
* Java实体类(bean)动态排序
*
* @author seesun2012@163.com
*
*/
public class BeanSortTest {
public static void main(String[] args){ Student s = new Student();
s.setId(1);
s.setName("张三");
s.setScore(80.00); Student s1 = new Student();
s1.setId(2);
s1.setName("李四");
s1.setScore(100.00); Student s2 = new Student();
s2.setId(3);
s2.setName("王五");
s2.setScore(59.99); List<Student> list = new ArrayList<Student>();
list.add(s);
list.add(s1);
list.add(s2); System.out.println("排序前:");
for (Student sd : list) {
System.out.println(sd);// 输出所有对象
} ////////////// 进行排序(特别注意,这里可以动态入参)//////////////
Collections.<Student> sort(list, new BeanComparator<Student>("score"));
System.out.println("按成绩排序后:");
for (Student sd : list) {
System.out.println(sd);// 输出所有对象
} }
}

排序前:

学生编号:1,学生姓名:张三,分数:80.0

学生编号:2,学生姓名:李四,分数:100.0

学生编号:3,学生姓名:王五,分数:59.99


按【成绩】排序后:

学生编号:2,学生姓名:李四,分数:59.99

学生编号:1,学生姓名:王五,分数:80.0

学生编号:3,学生姓名:张三,分数:100.0


Java如何操作对象(bean)进行动态排序?的更多相关文章

  1. 086、Java数组之对象数组的动态初始化

    01.代码如下: package TIANPAN; class Book { private String title; private double price; public Book(Strin ...

  2. java 集合框架(TreeSet操作,自动对数据进行排序,重写CompareTo方法)

    /*TreeSet * treeSet存入数据后自动调用元素的compareTo(Object obj) 方法,自动对数据进行排序 * 所以输出的数据是经过排序的数据 * 注:compareTo方法返 ...

  3. java设计模式--基础思想总结--父类引用操作对象

    看设计模式的相关书籍也有一段时间了,一开始其实是抱着作为java三大框架的基础知识储备来学习的,不过到后来,才发现,在设计模式的一些准则装饰下,java的面向对象威力才真正地体现出来,后面的将会陆续地 ...

  4. 有关java的引用传递,直接操作对象本身。直接删除BE的value中某值

    HashSet<String> refRegions = BE.get(regionName);    HashSet<String> values = new HashSet ...

  5. 危险代码:如何使用Unsafe操作内存中的Java类和对象

    危险代码:如何使用Unsafe操作内存中的Java类和对象—Part1 危险代码:如何使用Unsafe操作内存中的Java类和对象—Part2 危险代码:如何使用Unsafe操作内存中的Java类和对 ...

  6. java实现两个不同list对象合并后并排序

    工作上遇到一个要求两个不同list对象合并后并排序1.问题描述从数据库中查询两张表的当天数据,并对这两张表的数据,进行合并,然后根据时间排序.2.思路从数据库中查询到的数据放到各自list中,先遍历两 ...

  7. java工具类之按对象中某属性排序

    import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang ...

  8. java中对对象进行判空的操作--简洁编码

    java中对对象进行判空的操作 首先来看一下工具StringUtils的判断方法: 一种是org.apache.commons.lang3包下的: 另一种是org.springframework.ut ...

  9. Java中把对象、对象bean、list集合、对象数组、Map和Set以及字符串转换成Json

    对象转换为Json 对象bean转换为Json List集合转换为Json 对象数组转换为Json Map集合转换为Json Set集合转为Json 字符串转换为Json 把Java对常用的一些数据转 ...

随机推荐

  1. ASP.NET基于NPOI导出数据

    using System; using System.Collections; using System.Collections.Generic; using System.IO; using Sys ...

  2. 【Asp.net MVC】AJAXHelper 和jQueryAjax

    在ASP.NET MVC中,有一个官方提供的AJAXHelper帮助我们做AJAX相关的东西.我用传统的jQuery AJAX技术和AJAXHelper分别实现同一个demo,特此记录一下. 由于是在 ...

  3. Impala源码之订阅发布系统的实现

    本文由  网易云发布. 作者:冯宇 本篇文章仅限内部分享,如需转载,请联系网易获取授权. 本文是Impala源码笔记的第一篇,本文主要根据源代码学习一下statestored模块的实现,众所周知,Im ...

  4. AHOI2012 信号塔 | 最小圆覆盖模板

    题目链接:戳我 最小圆覆盖. 1.枚举第一个点,考虑当前圆是否包含了这个点,如果没有,则把圆变成以这个点为圆心,半径为0的圆. 2.枚举第二个点,考虑圆是否包含了这个点,如果没有,则把圆变成以这两个点 ...

  5. 正则表达式的Wed验证应用(40)

    电子邮件地址的校验 <?php /* 校验邮件地址*/ function checkMail($email) { //用户名,由“\w”格式字符.“-”或“.”组成 $email_name= & ...

  6. codeforces 1096 题解

    A: 发现最优的方案一定是选 $ l $ 和 $ 2 * l $,题目保证有解,直接输出即可 #include <bits/stdc++.h> #define Fast_cin ios:: ...

  7. Qt5学习笔记(消息基础)

    #include "MyWidget.h" #include <QApplication> #include <QEvent> #include <Q ...

  8. linux防火墙(五)—— 防火墙的规则备份与还原

    一.第一种备份还原用法,使用工具 iptables-save >/opt/iprules.txt iptables-restore < /opt/iprules.txt #注意导入的文件必 ...

  9. [转]CocoaPods安装和使用教程

    [转载自:http://code4app.com/article/cocoapods-install-usage] 目录 CocoaPods是什么? 如何下载和安装CocoaPods? 如何使用Coc ...

  10. CentOS 7 安装方式汇总

    U盘安装 通过U盘安装 CentOS 的过程和安装Windows非常相似,首先将 CentOS 镜像文件刻录到U盘(或者光盘),设置固件(BIOS或者UEFI)从U盘启动,然后逐步设置即可. 使用 V ...