取得相同id 下日期最大的对象

本文介绍了一个Java程序示例,该程序使用了ArrayList和TreeMap等数据结构来存储和处理一系列特定格式的数据记录。通过对这些记录进行解析并根据其时间属性进行排序,最终将数据映射到一个TreeMap中,以便于快速查找最新的记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.util.ArrayList;
import java.util.Map;
import java.util.TreeMap;

public class Data {

    private String item;
    // private String objType;
    private String time;
    private String time1;

    public Data(String chaine) throws Exception {
    String s[] = chaine.split(" ");
    this.item = s[0];
    // this.objType = s[1];
    this.time = s[1] + " " + s[2];
    }

    public String getTime() {
    return time;
    }

    public String getTime1() {
    return time1;
    }

    public String getKey() {
    return item + " " + item;
    }

    public String toString() {
    return item + " " + time;
    }

    public static void main(String[] args) throws Exception {
    ArrayList<Data> dataList = new ArrayList<Data>();
    dataList.add(new Data("00000ar6n8xlg00b 2012/7/1 23:36:52 "));
    dataList.add(new Data("000i0ar6o6262twu 2012/7/19 20:56:41 2012/8/30 10:30:04"));
    dataList.add(new Data("000i0ar6o7435u08 2012/7/20 10:35:46 2012/8/24 13:15:14"));
    dataList.add(new Data("00000ar6n8xlg00b 2012/7/1 23:36:52 "));
    dataList.add(new Data("000i0ar6o6262twu 2012/8/23 17:14:40 2012/8/24 10:29:54"));
    dataList.add(new Data("000i0ar6o7435u08 2012/7/20 11:37:30 "));
    dataList.add(new Data("00000ar6n8xlg00b 2012/8/29 13:47:02 "));
    dataList.add(new Data("000i0ar6o6262twu 2012/8/29 13:47:02 "));
    dataList.add(new Data("000i0ar6o7435u08 2012/8/29 13:47:02 "));
    Map<String, Data> dataMap = new TreeMap<String, Data>();
    for (Data data : dataList) {
        if (!dataMap.containsKey(data.getKey()))
        dataMap.put(data.getKey(), data);
        else {
        if (data.getTime().compareTo(dataMap.get(data.getKey()).getTime()) > 0) {
            dataMap.put(data.getKey(), data);
        }
        }
    }
    System.out.println(dataMap.values());
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值