clean codes和bug集锦

9 篇文章 0 订阅
6 篇文章 0 订阅

一些经常出现的bug的地方

NPE空指针

  1. 基本类型 获取包装类型的结果
    JSONObject jsonObj = …
    boolean isFastigium = jsonObj.getBoolean(“fastigium”);
    应该改为
    boolean isFastigium = jsonObj.getBooleanValue(“fastigium”);

  2. 将异常信息转为字节数组
    exception.getMessage().getBytes(“UTF-8”);
    .getMessage()定义在Throwable默认是null

  3. ThreadLocal初始化的地方错误

 private static ThreadLocal<Boolean> isDebug = new ThreadLocal<Boolean>();
  static {
        isDebug.set(false);
    }

这种初始化是无意义的 boolean = isDebug.get()会出现转换NPE
正确的初始化写法

private static ThreadLocal<Boolean> isDebug = new ThreadLocal<Boolean>(){
        @Override
        protected Boolean initialValue() {
            return false;
        }
    };

clean codes会增加阅读性,有助于减少BUG

  1. 了解API设计者的意图
 String studentSafeName = StringUtils.isBlank(studentUser.getName()) ? studentUser.getUsername() : studentUser.getName();
                        Object[] params = new String[]{
                                studentSafeName,
                                df.format(scheduledTime),
                                teacherUser.getName(),
                                lesson.getSerialNumber(),
                                lesson.getName()
                        };
                        String message = String.format(templateCancelMajor, params);

上面的代码比较啰嗦

查看相似API<String> String org.apache.commons.lang3.StringUtils.defaultIfBlank(String str, String defaultStr)
和查看具体的参数类型
String java.lang.String.format(String format, Object... args)

改写为下面

String name = StringUtils.defaultIfBlank(studentUserProfile.getName(), student.getEnglishName());
            String message = String.format(templateBookedMajors, name, teacherUser.getName(), SDF.format(scheduledTime),
                    lesson.getSerialNumber(), lesson.getName());

2.选择合适的工具类,尽量让代码看起来干净

private long initData(List<Long> onlineClassIds) {
        AtomicInteger fixCount = new AtomicInteger();
        List<Future<Boolean>> futureTasks = new ArrayList<>();
        onlineClassIds.forEach((id) -> {
            Future<Boolean> future = executor.submit(() -> {
                return dbyClassroomService.fixClassroomDocuments(id);
            });
            futureTasks.add(future);
        });

        futureTasks.forEach((future) -> {
            try {
                if (future.get()) {
                    fixCount.incrementAndGet();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        logger.info("fixCount={}, ", fixCount);
        return fixCount.get();
    }



改为

public int initData(List<Long> onlineClassIds) {
        if (onlineClassIds.isEmpty()) {
            return 0;
        }
        AtomicInteger fixCount = new AtomicInteger();
        CountDownLatch latch = new CountDownLatch(onlineClassIds.size());
        onlineClassIds.forEach(config -> {
            executor.execute(() -> {
                // ...
                fixCount.incrementAndGet();
                latch.countDown();
            });
        });
        try {
            latch.await();
        } catch (InterruptedException e) {
            logger.error("latch.await err:{},", e);
        }
        logger.info("all inited time used{},", fixCount);
        return fixCount.get();
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值