Java之道:14个写Java 的好习惯

Java专栏

共 1937字,需浏览 4分钟

 · 2023-06-20


胖虎和朋友原创的视频教程有兴趣的可以看看


(文末附课程大纲)


👏2023 最新,Java成神之路,架构视频(点击查看)


😉超全技术栈的Java入门+进阶+实战!(点击查看)


作者: 国涛i
来源: blog.csdn.net/weixin_44912855/article/details/120866194

Part1定义配置文件信息

有时候我们为了统一管理会把一些变量放到yml配置文件中

例如@ConfigurationProperties 代替@Value

使用方法

定义对应字段的实体

@Data
// 指定前缀
@ConfigurationProperties(prefix = "developer")
@Component
public class DeveloperProperty {
    private String name;
    private String website;
    private String qq;
    private String phoneNumber;
}

使用时注入这个bean

@RestController
@RequiredArgsConstructor
public class PropertyController {
 
    final DeveloperProperty developerProperty;
 
    @GetMapping("/property")
    public Object index() {
       return developerProperty.getName();
    }
}

Part2用@RequiredArgsConstructor代替@Autowired

我们都知道注入一个bean有三种方式哦(set注入, 构造器注入, 注解注入),spring推荐我们使用构造器的方式注入Bean

我们来看看上段代码编译完之后的样子RequiredArgsConstructor:lombok提供

Part3代码模块化

阿里巴巴Java开发手册中说到每个方法的代码不要超过50行(我没记错的话)

在实际的开发中我们要善于拆分自己的接口或方法, 做到一个方法只处理一种逻辑, 说不定以后某个功能就用到了, 拿来即用

Part4抛异常而不是返回

在写业务代码的时候,经常会根据不同的结果返回不同的信息,尽量减少返回,会显得代码比较乱

反例正例

Part5减少不必要的db

尽可能的减少对数据库的查询

举例子

删除一个服务(已下架或未上架的才能删除)

之前有看别人写的代码,会先根据id查询该记录,然后做一些判断

反例正例

Part6不要返回null

反例正例别处调用方法时,避免不必要的空指针

Part7if else

不要太多了if else if

可以试试策略模式代替

Part8减少controller业务代码

业务代码尽量放到service层进行处理,后期维护起来也好操作而且美观

反例正例

Part9利用好Idea

目前为止市面上的企业基本都用idea作为开发工具了吧

举一个小例子

idea会对我们的代码进行判断,提出合理的建议

例如:它推荐我们用lanbda的形式代替

点击replace

Part10基础问题

map遍历

HashMap map = new HashMap<>();
map.put("name""du");
for (String key : map.keySet()) {
    String value = map.get(key);
}

map.forEach((k, v) -> {

});

// 推荐
for (Map.Entry entry : map.entrySet()) {

}

optional 判空

//获取子目录列表
public List getChild(String pid) {
        if (V.isEmpty(pid)) {
        pid = BasicDic.TEMPORARY_DIRECTORY_ROOT;
    }
    CatalogueTreeNode node = treeNodeMap.get(pid);

    return Optional.ofNullable(node)
            .map(CatalogueTreeNode::getChild)
            .orElse(Collections.emptyList());
}

Part11判断元素是否存在

hashSet而不是list

list判断一个元素是否存在的代码

ArrayList list = new ArrayList<>();
 
// 判断a是否在list中
 
for (int i = 0; i < list.size(); i++){
   if ("a".equals(elementData[i])){
      return i;
   }
}

由此可见其复杂度为On

而hashSet底层采用hashMap作为数据结构进行存储,元素都放到map的key(即链表中)

HashSet set = new HashSet<>();
 
// 判断a是否在set中
 
int index = hash(a);
 
return getNode(index) != null

胖虎联合两位大佬朋友,知名培训机构讲师和科大讯飞架构,联合打造了《Java架构师成长之路》的视频教程。完全对标外面2万左右的培训课程。

除了基本的视频教程之外,还提供了超详细的课堂笔记,以及源码等资料包..


目前课程内测活动价:999元后续可能会上调至 2999元


点击下方超链接查看详情(或者点击文末阅读原文):

(点击查看)  2023年,最新Java架构师成长之路 视频教程!

以下是课程大纲,大家可以长按识别查看!


浏览 30
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报