list1.Sort((m, n) => m.Id - n.Id); id是double类型的为什么回报错

本文讲述了在.NET编程中,为何不能直接对double类型的属性进行减法操作进行排序,以及提供了解决方案,包括使用CompareTo方法进行比较和创建自定义比较器。重点介绍了CompareTo方法的工作原理和在排序中的应用,以及如何避免精度损失。
摘要由CSDN通过智能技术生成

问题产生的地方

 

原因 

对于 double 类型的属性,不能直接使用减法运算符进行比较。减法运算符只能用于数值类型,而 double 是浮点数类型。

要在 double 属性上进行排序,可以使用 CompareTo 方法或者使用自定义的比较器。

更改

要在 double 属性上进行排序,可以使用 CompareTo 方法或者使用自定义的比较器。下面是两种可行的方式:

1.使用 CompareTo 方法:

list1.Sort((m, n) => m.Id.CompareTo(n.Id));

使用了 CompareTo 方法来比较两个 double 值的大小

2.使用自定义的比较器:

public class DoubleComparer : IComparer<double>
{
    public int Compare(double x, double y)
    {
        return x.CompareTo(y);
    }
}

// 在排序时使用自定义的比较器
list1.Sort((m, n) => new DoubleComparer().Compare(m.Id, n.Id));

这种写法定义了一个名为 DoubleComparer 的自定义比较器类,实现了 IComparer<double> 接口的 Compare 方法。然后,在排序时使用新建的 DoubleComparer 实例来进行比较。

产生原因

如:list1.Sort((m, n) => m.Id - n.Id);id为double类型,为什么会报错无法将都变了隐式转换为int,为什么会报错无妨将lambda表达式转换成预期委托类型

List<T>Sort 方法的参数是一个委托,用于比较两个元素的大小关系,以实现排序功能。这个委托类型的声明如下:

public delegate int Comparison<in T>(T x, T y);

可以将 lambda 表达式中的 m.Id - n.Id 修改为一个返回整数类型的表达式,比如 (int)(m.Id - n.Id)。这样就可以将 lambda 表达式转换成预期的委托类型,从而成功地实现按照 Id 属性进行排序的功能。

list.Sort((m, n) => m.PositionX - n.PositionX);

 m.PositionX - n.PositionX的结果是一个double 需要强转成int ,但是强转的时候会造成精度丢失 如本来是0.3 会变成0导致认为mn是相等的所以保险起见还是用

list.Sort((m, n) => m.PositionX.CompareTo(n.PositionX));

CompareTo方法 

CompareTo() 方法是用于比较两个值的大小,并返回一个整数作为比较结果的表示。

CompareTo() 方法的返回值为整数,其含义如下:

  • 如果 x 小于 y,则返回一个负数(通常为 -1)。
  • 如果 x 等于 y,则返回零。
  • 如果 x 大于 y,则返回一个正数(通常为 1)。

返回一个整数的好处是可以更灵活地处理比较结果。通过比较结果的正负号,可以判断出两个值的相对大小关系,并进行相应的逻辑处理。

CompareTo 方法是 IComparable 接口的一部分,它定义了一个用于比较对象的方法。因此,只要类实现了 IComparable 接口,就会拥有 CompareTo 方法。

以下是一些常见的具有 CompareTo 方法的类:

  1. Int32Int64DoubleDecimal 等数值类型:这些数值类型都实现了 IComparable 接口,并且提供了 CompareTo 方法来比较它们之间的大小关系。
  2. String 类型:String 类型实现了 IComparable 接口,因此它也具有 CompareTo 方法,用于按照字典顺序比较字符串的大小。
  3. DateTime 类型:DateTime 类型也实现了 IComparable 接口,并提供了 CompareTo 方法,用于比较日期和时间。
  4. 用户自定义类:如果你在自己的类中实现了 IComparable 接口,并提供了 CompareTo 方法的实现,那么你的类也会具有 CompareTo 方法。

 

  • 23
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
public Map<String, Object> kaoYanAllStation() { Map<String, Object> map = new HashMap<>(); //获取上个月月份 String month = DateUtil.month(DateUtil.lastMonth()) + 1 + ""; //获取历年同期降水数据 Double historyPreValue = ComData.historyPre().get(month); //获取历年同期温度数据 Double historyTemValue = ComData.historyTem().get(month); //获取去年同期降水数据 List<JSONObject> lastYearPre = prodBookmarkValueService.tableData(ComData.getLastYearDate(), "SUM_PRE_Time_2020"); //获取上月降水数据 List<JSONObject> lastMonthPre = prodBookmarkValueService.tableData(ComData.getLastMonthDate(), "SUM_PRE_Time_2020"); //获取去年同期温度数据 List<JSONObject> lastYearTem = prodBookmarkValueService.tableData(ComData.getLastYearDate(), "AVG_TEM_Avg"); //获取上月温度数据 List<JSONObject> lastMonthTem = prodBookmarkValueService.tableData(ComData.getLastMonthDate(), "AVG_TEM_Avg"); //定义比较器 Comparator<JSONObject> comparator = Comparator.comparing(o -> o.getStr("Station_Id_C")); lastMonthPre.sort(comparator); lastYearPre.sort(comparator); lastYearTem.sort(comparator); lastMonthTem.sort(comparator); // List<String> stationName = lastMonthPre.stream().map(o -> o.getStr("Station_Name")).collect(Collectors.toList()); //上月降水 { //上月降水 List<Double> sumPre = lastMonthPre.stream().map(o -> o.getDouble("SUM_PRE_Time_2020")).collect(Collectors.toList()); //较历年 List<Double> hisPre = lastMonthPre.stream().map(o -> o.getDouble("SUM_PRE_Time_2020") - historyPreValue).collect(Collectors.toList()); //较去年 List<Double> lastYearSumPre = lastYearPre.stream().map(o -> o.getDouble("SUM_PRE_Time_2020")).collect(Collectors.toList()); List<Double> lastYearPreList = new ArrayList<>(); for (int i = 0; i < sumPre.size(); i++) { lastYearPreList.add(sumPre.get(i) - lastYearSumPre.get(i)); } map.put("sumPre", sumPre); map.put("hisPre", hisPre); map.put("lastYearPreList", lastYearPreList); } { //上月温度 List<Double> tem = lastMonthTem.stream().map(o -> o.getDouble("AVG_TEM_Avg")).collect(Collectors.toList()); //较历年 List<Double> hisTem = lastMonthTem.stream().map(o -> o.getDouble("AVG_TEM_Avg") - historyTemValue).collect(Collectors.toList()); //较去年 List<Double> lastYearSumTem = lastYearTem.stream().map(o -> o.getDouble("AVG_TEM_Avg")).collect(Collectors.toList()); List<Double> lastYearTemList = new ArrayList<>(); for (int i = 0; i < tem.size(); i++) { lastYearTemList.add(tem.get(i) - lastYearSumTem.get(i)); } map.put("tem", tem); map.put("hisTem", hisTem); map.put("lastYearTemList", lastYearTemList); } // map.put("stationName", stationName); return map; } 以上代码如何优化.请用中文答我
02-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值