《Java开发手册》是阿里巴巴集团技术团队的集体智慧结晶和经验总结,经历了多次大规模一线实战的检验及不断完善,公开到业界后,众多社区开发者踊跃参与,共同打磨完善,系统化的整理成册。
会当凌绝顶,一览众山小。经过一年的修炼,《Java开发手册》泰山版于4.22正式发布。此次泰山版发布,将带来三大亮点:新增5条日期时间规约;新增2条表别名sql规约;新增统一错误码规约:
接下来,让笔者带你一起解读最新泰山版本新增的3项规约。
日期时间规约
如下图所示,新增的日期时间规约归属于第一部分:编程规约:
这一段总计此次新增了7个规约条例,前五条全部是强制类型的:
日期格式化时,传入pattern中表示年份统一使用小写的y。解读:yyyy表示当天所在的年,而大写的YYYY代表是 week in which year。意思是当天所在的周所属的年份,一周从周日开始,周六结束,只要本周跨年,返回的YYYY就是下一年。
在日期格式中分清楚大写的 M 和小写的 m,大写的 H 和小写的 h 分别指代的意义。解读:大写M表示月份,小写m表示分钟。大写H表示24小时制,小写h表示12小时制。
获取当前毫秒数:System.currentTimeMillis(); 而不是 new Date().getTime()。 解读:System.currentTimeMillis()是一个native方法,依赖操作系统,性能更好。
不允许在程序任何地方中使用:1)java.sql.Date 2)java.sql.Time 3)java.sql.Timestamp。**解读:第 1 个不记录时间,getHours()抛出异常;第 2 个不记录日期,getYear()抛出异常;第 3 个在构造方法 super((time/1000)*1000),fastTime 和 nanos 分开存储秒和纳秒信息。
不要在程序中写死一年为 365 天,避免在公历闰年时出现日期转换错误或程序逻辑 错误。
后两条是推荐类型的:
避免公历闰年 2 月问题。闰年的 2 月份有 29 天,一年后的那一天不可能是 2 月 29 日。解读:打个比方,某个任务想一年运行一次,那么cron表达式不要写成:0 0 0 29 2 ?。而应该写成:0 0 0 28 2 ?。前一个表达式实际上是4年才执行一次,后一个表达式才是一年执行一次。
使用枚举值来指代月份。如果使用数字,注意 Date,Calendar 等日期相关类的月份 month 取值在 0-11 之间。解读:Calendar.JANUARY的值实际上就是0(Calendar中定义为:public final static int JANUARY = 0)。
2条表别名sql规约
此次泰山版新增了两条表别名sql规约。一条是强制的,一条是推荐的。
[强制] 对于数据库中表记录的查询和变更,只要涉及多个表,都需要在列名前加表的别名(或表名)进行限定。说明:对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表的别名(或表名),并且操作列在多个表中存在时,就会抛异常,相信大家都碰到过Column 'xxxx' in field list is ambiguous这个异常提示吧。正例:select t1.name from table_first as t1 , table_second as t2 where t1.id=t2.id;
[建议] SQL语句中表的别名前加as,并且以 t1、t2、t3、...的顺序依次命名。说明:1)别名可以是表的简称,或者是根据表出现的顺序,以 t1、t2、t3 的方式命名。2)别名前加as使别名更容易识别。参考正例:select t1.name from table_first as t1, table_second as t2 where t1.id=t2.id。
统一错误码规约
如下图所示,新增的统一错误码规约是一个全新的部分,即附3。错误码定义对每一个系统的重要性不言而喻,可以说必不可少。良好的错误码定义能让API的结果变得更易懂,同时能大大提升排查问题效率,并且还可以针对每个异常码出现的次数做实时监控:
如下图所示,是截取的部分错误码。完整版请下载最新的Java开发手册泰山版,下载地址为https://developer.aliyun.com/topic/java2020:
需要【阿里Java开发手册泰山版】电子书的老铁,转发+关注,私信回复“阿里”即可获得免费领取方式
网友评论