通过java记录数据持续变化时间代码解析
更新时间:2020年01月15日 11:23:09 作者:郑某人1
这篇文章主要介绍了通过java记录数据持续变化时间代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
这篇文章主要介绍了通过java记录数据持续变化时间代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
1.需求:获取count为null和不为null的持续变化
[{count=0, time=0}, {count=10, time=1000}, {count=20, time=2000}, {count=30, time=3000}, {count=40, time=4000}, {count=null, time=5000}, {count=null, time=6000}, {count=null, time=7000}, {count=null, time=8000}, {count=null, time=9000}, {count=100, time=10000}, {count=110, time=11000}, {count=120, time=12000}, {count=130, time=13000}, {count=140, time=14000}]
2.代码如下:
package com.stop; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * static boolean temp_flag; // 记录容器 public void execute(boolean flag) { if (temp_flag == flag) { // 没有变化 } else { if (flag == false) { // 上次是true,本次是false } else { // 上次是false本次是true } } } */ public class Test { public static List<Map<String, Object>> buildList() { List<Map<String, Object>> items = new ArrayList<>(); for(int i=0;i<5;i++) { Map<String,Object> map = new HashMap<>(); map.put("time", i*1000); map.put("count", i*10); items.add(map); } for(int i=5;i<10;i++) { Map<String,Object> map = new HashMap<>(); map.put("time", i*1000); map.put("count", null); items.add(map); } for(int i=10;i<15;i++) { Map<String,Object> map = new HashMap<>(); map.put("time", i*1000); map.put("count", i*10); items.add(map); } return items; } public static void main(String[] args) { // 构造数据 List<Map<String, Object>> items = buildList(); List<Map<String, Object>> list = new ArrayList<>(); boolean isStop = false;// 记录容器 for (int i = 0; i < items.size(); i++) { boolean flag = items.get(i).get("count") == null; if (i == 0) { Map<String, Object> map = new HashMap<>(); if (flag) { map.put("stop", items.get(i).get("time")); isStop = true; } else { map.put("recover", items.get(i).get("time")); } list.add(map); continue; } if (isStop == flag) { // 没有变化 } else { isStop = flag; Map<String, Object> map = new HashMap<>(); if (!flag) { // 上次是true,本次是false map.put("recover", items.get(i).get("time")); } else { // 上次是false本次是true map.put("stop", items.get(i).get("time")); } list.add(map); } } System.out.println(list); } }
3.运行main方法结果
[{recover=0}, {stop=5000}, {recover=10000}]
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
springboot查看和修改内置tomcat版本的方法步骤
本文主要介绍了springboot查看和修改内置tomcat版本的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2024-07-07mybatis QueryWrapper的条件构造之apply、last、select解析
这篇文章主要介绍了mybatis QueryWrapper的条件构造之apply、last、select,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-03-03详细分析Java中String、StringBuffer、StringBuilder类的性能
在Java中,String类和StringBuffer类以及StringBuilder类都能用于创建字符串对象,而在分别操作这些对象时我们会发现JVM执行它们的性能并不相同,下面我们就来详细分析Java中String、StringBuffer、StringBuilder类的性能2016-05-05解决springboot配置文件组解决自动配置属性无法注入问题
在使用Spring Boot时,可能会遇到配置文件属性注入失败的问题,本文描述了一个案例,其中尝试使用profile文件组指定不同环境下的配置文件,但遇到了属性无法成功注入的情况,提供的解决办法是将Spring Boot的版本号从2.2.0.RELEASE升级到2.4.02024-09-09
最新评论