Java | Comparator接口 & Comparable接口 & 集合排序

助记:名词【Comparator(比较器)】作为参数传递,形容词【Comparable<?>(可比较的)】需要去实现。

ComparatorComparable
类型供需要比较的类实现方法(内部比较)将其实现类作为参数(外部比较)
方法int compare(Person o1, Person o2)int compareTo(Object o)
方法说明第一个参数为基准,第二个是与之比较的元素 。
返回正数基准在后;返回负数基准在前。
本类为基准,参数为比较的元素 。
返回正数基准在后;返回负数基准在前 。
返回值1升序:基准 - 比较者(第一个 - 第二个)
升序:return o1.a - o2.a;
升序:基准 - 比较者(第一个 - 第二个)
升序:return this.a - o.a;
返回值2对于字符串(升序):return o1.getValue().compareTo(o2.getValue());

返回值2:

Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
            //升序排序,第一个o1为基准,第二个o2为被比较值;返回值中o1在o2前面,倒序反过来就可以了。
            public int compare(Map.Entry<String, String> o1, Map.Entry<String, String> o2) {
                return o1.getValue().compareTo(o2.getValue());
            }
        });

总结:
正序:返回值时,基准放前面作为被减数;倒序:返回值时基准放后面作为减数,两个都是一样。如上面代码,调用字符串compareTo()方法也是一样的规律。

1. Comparator<?>

问号为要比较的集合元素

//1.比较的类
public class Person {

    private int age;
    private String name;

    //get.set方法。。。。
}

//2. 实现Comparator<?>
public class PersonComparator implements Comparator<Person> {

  // 第一个参数可以理解为基准,第二个是与之比较的元素 。返回负数表示排在其前面,返回正数表示排在其后面

    @Override
    public int compare(Person o1, Person o2) {
        // 返回负数表示o1排在o2前面
        if (o1.getAge() > o2.getAge()) {
            return -1;
        }

        // 返回正数表示o1排在o2后面
        if (o1.getAge() < o2.getAge()) {
            return 1;
        }
        return 0;
    }

}

2. Comparable<?>

问号为要比较的集合元素

public class Person implements Comparable<Person> {

    private int age;
	// ... get/set方法 ...


    @Override
    public int compareTo(Person comparedUser) {
        // 返回负数表示this对象排在comparedUser前面
        if (this.age > comparedUser.getAge()) {
            return -1;
        }
        // 返回正数表示this对象排在comparedUser后面
        if (this.age < comparedUser.getAge()) {
            return 1;
        }
		
        return 0;
        
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值