猿创征文 第二季| #「笔耕不辍」--生命不息,写作不止#

8,891 阅读2分钟

空间复杂度、时间复杂度考虑进去有利于实现高质量代码

空间复杂度、时间复杂度考虑进去有利于实现高质量代码、
没有必要的for循环或者多余的for利用其他方法优化调。
for循环里面不建议操作增删改查数据库,可以add好一个集合,批量插入数据库
为了方便调用同一个方法的前提是不对速度影响,或或者极小,否则宁愿多写一个方法,而不是为了省事而调用同一个方法。
多余的req和resp都是影响速度性能的潜在因素,所以建议减少不必要字段。
如果数据量不大的查询性能慢,为什么不思考一下是代码空间复杂度、时间复杂度,nn,nn*n,(n+1)*n。。。呢

该用户所在的部门树

该用户所在的部门树
根据用户id查询所在的部门和所有的父部门

SELECT T2.id, T2.name 
FROM ( 
    SELECT 
        @r AS _id, 
        (SELECT @r := parent_id FROM sys_dept WHERE id = _id) AS parent_id, 
        @l := @l + 1 AS lvl 
    FROM 
        (SELECT @r := #{deptId}, @l := 0) vars, 
        sys_dept h 
    WHERE @r <> 0) T1 
JOIN sys_dept T2 
ON T1._id = T2.id 
ORDER BY T1.lvl DESC

组装redis key

    public final static String PARAMETER_PASSING_REDIS_KEY = "parameter:passing:{0}:{1}:{2}:{3}";

    @Test
    public void StringRedisKey() {
        Long merchantId = 1L;
        String dataRightsObjectCode = "REPORT_OBJECT";
        Long userId = 23L;
        String format = MessageFormat.format(PARAMETER_PASSING_REDIS_KEY,
                merchantId.toString(),
                dataRightsObjectCode,
                userId.toString(),
                UUID.randomUUID().toString().replace("-", ""));
        System.out.println(format);
    }


parameter:passing:1:REPORT_OBJECT:23:45f9b38b35f9490eb867ac2709355d7b


批量更新mybatis plus
----------------

//条件 UpdateWrapper updateWrapper = new UpdateWrapper<>(); updateWrapper.in("id", idList); //更新 MchDataAuthConfigRule rule = new MchDataAuthConfigRule(); rule.setStatus(100); int update = mchDataAuthConfigRuleMapper.update(rule, updateWrapper); log.info("update:{}", update);


redis插入并且设置失效时间
---------------

// 缓存条件对应的id
redisUtil.hSet(genKey(req), req.getMonth().toString(), JSON.toJSONString(genProjectIds));
redisUtil.hmSet(genKeyForOne(req), projectIdMap);
// 为尽可能使2个key的失效时间一致,所以等2个都插入完毕后再设置失效时间
redisUtil.getRedisTemplate().expire(genKey(req), EXPIRE_TIME, TimeUnit.SECONDS);
redisUtil.getRedisTemplate().expire(genKeyForOne(req), EXPIRE_TIME, TimeUnit.SECONDS);
return allProject ? genProjects : genProjects.stream()
    .filter(project -> ReportConstant.abnormal.equals(project.getAbnormalFlag())).collect(Collectors.toList());

为什么会没有内存了呢
----------

为什么会没有内存了呢?原因不外乎有两点:  
1)分配的少了:比如虚拟机本身可使用的内存(一般通过启动时的VM参数指定)太少。  
2)应用用的太多,并且用完没释放,浪费了。此时就会造成内存泄露或者内存溢出。  
内存泄露:申请使用完的内存没有释放,导致虚拟机不能再次使用该内存,此时这段内存就泄露了,因为申请者不用了,而又不能被虚拟机分配给别人用。  
内存溢出:申请的内存超出了JVM能提供的内存大小,此时称之为溢出。

1、当发生OOM时,服务已基本不可用,并且会出现以下明显报错信息。  
2.JVM启动参数设置 -XX:+HeapDumpOnOutOfMemoryError 当发生OOM时自动输出堆的内存快照  
\-XX:HeapDumpPath=/tmp 输出目录将dump文件java\_pid1.hprof拷到本地如果忘记设置启动参数,也可以通过命令行获取dump文件使用JDK自带的jmap命令:jmap -dump:format=b,file=heap.bin  
3、本地先安装eclipse, 再安装MAT(Memory Analyzer Tool)工具,使用mat工具打开java\_pid1.hprof文件,根据mat可以快速定位问题

预防  
1、根据业务合理设置java内存大小,以及不定时查看业务运行时内存使用情况, 及时调整内存大小。  
2、在写代码时,应该有意识避免写查询大对象sql。  
3、针对循环业务要有意识避免内存不能释放进而导致OOM。

> 本文使用 [文章同步助手](https://juejin.cn/post/6940875049587097631) 同步