「Java开发者的福音」泰山版《Java开发手册》速览!附下载地址。

2024-01-01 17:58

本文主要是介绍「Java开发者的福音」泰山版《Java开发手册》速览!附下载地址。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

会当凌绝顶,一览众山小。经过一年的修炼,《Java 开发手册》泰山版于 4.22 正式发布。泰山版发布之后,我便立马去下载简单阅读了一下新增加了内容。

Guide 哥:我平时会经常拿出来看看,里面的很多精华都是阿里工程师踩坑而得,学到就可以立马用到,避免再犯同样的错误。

泰山版实际增加的内容不是很多,并没有太多的惊喜,毕竟它的内容本来就已经非常棒了,还是一如既往的实用!

相比于华山版来说主要增加了如下内容:

  1. 异常日志这块增加了对于错误码的规定;

  2. 编程规约这块主要增加了:

  • 关于日期和时间的一些约束

  • 集合处理这块增加了一些新的规定(大部分都和 Java8 新增加的特性有关);

  • 三目运算的自动拆箱可能导致 NPE 问题

  • sql 语句主要增加表的别名增加了两条规定;

  • 修改描述 90 处。比如,阻塞等待锁、建表的小数类型等。

  • 按照官方的来说这次总结可以概括为:

    本次泰山版是一次全新的革新,涉及到集合转化函数式接口中的深坑、年份天数写死所带来的问题、SQL 多表操作未加表名对字段限制惨案、以及统一错误码能够为我们带来的巨大好处。

    带大家简单看一下!

    增加了对于错误码的一些规定

    我在使用枚举简单封装一个优雅的 Spring Boot 全局异常处理! 这篇文章中也使用到了错误码,但是关于错误的码设计并没有完全满足阿里巴巴开发手册的要求。我之前设计错误码的时候只是单纯使用 4 位数字唯一表示每一种错误,并没有区分具体场景。而阿里巴巴开发手册它要求将错误产生来源分为 3 类,这样确实更好一点:

    1. A :错误来源于用户,比如参数错误,用户安装版本过低,用户支付 超时等问题;

    2. B :错误来源于当前系统,往往是业务逻辑出错,或程序健壮性差等问题;

    3. C :错误来源于第三方服务,比如 CDN 服务出错,消息投递超时等问题;

    错误码的第一位是错误产生来源,后四位数字编号从 0001 到 9999,比如 A0001 表示用户端错误。

    多表操作的话需要在字段前加上表的别名避免多表之间存在相同的名字(多表之间存在项目的相同名字的字段很常见)

    三目运算的自动拆箱可能导致 NPE 这个问题之前倒是没有注意过,算是一个小坑吧!

    切勿把天数写死,推荐使用 Java8 相关的日期类

    使用 java.util.stream.Collectors类的toMap()方法的时候要注意

    考虑到很多读者对这个方法不太了解,我写了一个简单的 Demo,大家感受一下:

    public class ToMapDemo {public static void main(String[] args) {List<ProgramLanguage> lt = new ArrayList<>();lt.add(new ProgramLanguage(1, "Java"));lt.add(new ProgramLanguage(2, "C++"));lt.add(new ProgramLanguage(2, "Python"));Map<Integer, String> map = lt.stream().collect(Collectors.toMap(ProgramLanguage::getId, ProgramLanguage::getName,(x, y) -> x + ", " + y));map.forEach((x, y) -> System.out.println(x + "=" + y));}static class ProgramLanguage {// keyprivate Integer id;// valueprivate String name;public ProgramLanguage(Integer id, String name) {this.id = id;this.name = name;}public Integer getId() {return id;}public String getName() {return name;}}
    }
    

    输出:

    1=Java
    2=C++, Python
    

    toMap方法如下,可以看出这个方法默认返回的是 HashMap,前两个参数一个是获取 key,一个是获取 value,第三个参数的作用是处理相同 key 的情况。

        Collector<T, ?, Map<K,U>> toMap(Function<? super T, ? extends K> keyMapper,Function<? super T, ? extends U> valueMapper,BinaryOperator<U> mergeFunction) {return toMap(keyMapper, valueMapper, mergeFunction, HashMap::new);}

    更多内容还需要自己去探索啦!

    配合阿里巴巴对应开发的插件— Alibaba Java Code Guidelines(阿里巴巴 Java 代码规范)效果更佳哦!我在《安利 10 个让你爽到爆的 IDEA 必备插件》这篇文章中也推荐到了这个插件。

    阿里巴巴 Java 代码规范,对应的 Github 地址为:https://github.com/alibaba/p3c

    下载地址:https://gitee.com/SnailClimb/awesome-java/raw/master/books/%E6%B3%B0%E5%B1%B1%E7%89%88%E3%80%8AJava%E5%BC%80%E5%8F%91%E6%89%8B%E5%86%8C%E3%80%8B.pdf

    推荐阅读
    十年老码农,现场教你写简历!
    安利10个让你爽到爆的IDEA必备插件
    深夜,分享一个Git小技巧
    编程·思维·职场
    欢迎扫码关注

这篇关于「Java开发者的福音」泰山版《Java开发手册》速览!附下载地址。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/560062

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory