在Java中使用Comparable接口按值对LinkedHashMap进行排序


prtyaa
prtyaa 2024-01-09 21:55:09 51964 赞同 0 反对 0
分类: 资源 标签: 运维
LinkedHashMap是一个通用类,用于实现Map接口。此外,它是 HashMap 类的子类,因此它可以使用 HashMap 类的所有方法并执行类似的操作。 Java提供了多种对LinkedHashMap进行排序的方法,我们将通过本文学习如何使用Comparable接口创建它并按其值进行排序。

按值对LinkedHashMap进行排序的程序

在直接跳到排序程序之前,让我们先看一下几个概念 –

LinkedHashMap

正如我们之前讨论的,LinkedHashMap 类扩展了 HashMap 类来实现 Map 接口。它维护键值对。 Key 是一个用于获取和接收与其关联的值的对象。它将映射的元素按照插入的顺序存储在 LinkedList 中,即它维护元素的插入顺序。此外,每当我们返回其元素时,它都会按插入顺序打印。

LinkedHashMap 的一般语法如下 –

语法

LinkedHashMap nameOfMap = new LinkedHashMap();

在上述语法中,

TypeOfKey − 指定键的数据类型。

TypeOfValue − 指定将要存储在映射中的值的数据类型。

nameOfMap − 给你的地图取一个合适的名字。

类似的界面

Java提供了多种排序算法和方法,可以帮助我们对数组、列表或任何集合进行排序。当我们想要按自然顺序对自定义对象进行排序时,可比较接口是一种非常有用的附加方法。例如,它按字典顺序对字符串进行排序,按数字顺序对数字进行排序。该接口在“java.lang”包中可用。

语法

class nameOfclass implements Comparable

compareTo()方法

Comparable 接口仅定义了一个名为“CompareTo”的方法,可以覆盖该方法以对对象集合进行排序。它提供了将类的对象与其自身进行比较的能力。当“this”对象等于传递的对象时,它返回 0,如果“this”对象更大,则返回正值,否则返回负值。

语法

compareTo(nameOfclass nameOfobject);

Collections.sort()方法

集合接口的“Collections”类提供了一个名为“Collections.sort()”的静态方法,可以对指定集合(如 ArrayList 或 LinkedList)的元素进行排序。它在“java.util”包中可用。

语法

Collections.sort(nameOfcollection);

算法

  • 步骤 1 – 创建一个实现Comparable接口的类’Cart’。在类内部,声明两个变量,并定义一个构造函数,该构造函数带有两个参数’item’和’price’,分别为字符串和双精度浮点数类型。

  • 第 2 步 – 进一步,我们将使用“toString()”方法将对象的数据转换为字符串。然后,定义“compareTo”方法以及“Cart”类的对象作为参数,以将“this”对象与新创建的对象进行比较。

  • 第三步 – 现在,在main()方法中,声明一个名为’obj’的LinkedHashMap类的’Cart’对象,并使用名为’put()’的内置方法将对象的详细信息存储到其中。’item’是键,其对应的值是’price’。

  • 步骤 4 – 最后,定义一个名为“SrtList”的 ArrayList 集合来存储 LinkedHashMap 的排序元素。现在,将“obj”作为参数传递给“Collections.sort()”方法,以按值执行排序操作。

示例

import java.util.*;
import java.lang.*;
public class Cart implements Comparable {
String item;
double price;
Cart(String item, double price) {
// this keyword shows these variables belongs to constructor
this.item = item;
this.price = price;
}
// method for converting object into string
public String toString() {
return “Item: ” + item + “, ” + “Price: ” + price;
}
public String getName() {
// to retrieve item name
return this.item;
}
// overriding method
public int compareTo(Cart comp) {
if(this.price > comp.price) {
return 1;
} else {
return -1;
}
}
public static void main(String[] args) {
// Declaring collection LinkedHashMap
LinkedHashMap obj = new LinkedHashMap();
// Adding object to the obj map
Cart obj1 = new Cart(“Rice”, 59);
obj.put(obj1.getName(), obj1);
Cart obj2 = new Cart(“Milk”, 60);
obj.put(obj2.getName(), obj2);
Cart obj3 = new Cart(“Bread”, 45);
obj.put(obj3.getName(), obj3);
// printing details obj map in unsorted order
System.out.println(“Elements of the map: “);
for (String unKey : obj.keySet()) {
System.out.println(obj.get(unKey));
}
List SrtList = new ArrayList(obj.values());
Collections.sort(SrtList);
// Sorting the object
// printing details of obj map in sorted order
System.out.println(“Elements of the newly sorted map: “);
System.out.println(SrtList);
}
}

输出

Elements of the map:
Item: Rice, Price: 59.0
Item: Milk, Price: 60.0
Item: Bread, Price: 45.0
Elements of the newly sorted map:
[Item: Bread, Price: 45.0, Item: Rice, Price: 59.0, Item: Milk, Price: 60.0]

结论

在 Java 1.0 版本中,首次引入了类似的接口,并在“java.lang”包中提供。在本文中,我们探索了LinkedHashMap以及Comparable接口在排序操作中的使用。

如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!

评价 0 条
prtyaaL2
粉丝 1 资源 1949 + 关注 私信
最近热门资源
银河麒麟桌面操作系统备份用户数据  129
统信桌面专业版【全盘安装UOS系统】介绍  128
银河麒麟桌面操作系统安装佳能打印机驱动方法  119
银河麒麟桌面操作系统 V10-SP1用户密码修改  108
麒麟系统连接打印机常见问题及解决方法  22
最近下载排行榜
银河麒麟桌面操作系统备份用户数据 0
统信桌面专业版【全盘安装UOS系统】介绍 0
银河麒麟桌面操作系统安装佳能打印机驱动方法 0
银河麒麟桌面操作系统 V10-SP1用户密码修改 0
麒麟系统连接打印机常见问题及解决方法 0
作者收入月榜
1

prtyaa 收益393.62元

2

zlj141319 收益218元

3

1843880570 收益214.2元

4

IT-feng 收益210.13元

5

风晓 收益208.24元

6

777 收益172.71元

7

Fhawking 收益106.6元

8

信创来了 收益105.84元

9

克里斯蒂亚诺诺 收益91.08元

10

技术-小陈 收益79.5元

请使用微信扫码

加入交流群

请使用微信扫一扫!