java 日期表达式_他来了,他带着 "阿里Java开发手册泰山版的解读" 走来了...

《Java开发手册》是阿里巴巴集团技术团队的集体智慧结晶和经验总结,经历了多次大规模一线实战的检验及不断完善,公开到业界后,众多社区开发者踊跃参与,共同打磨完善,系统化地整理成册。

会当凌绝顶,一览众山小。经过一年的修炼,《Java开发手册》泰山版于4.22正式发布。此次泰山版发布,将带来三大亮点:新增5条日期时间规约新增2条表别名sql规约新增统一错误码规约11b3a85ac7a7cc29092192d25effef52.png

接下来,让笔者阿飞带你一起解读最新泰山版本新增的3项规约。

日期时间规约

如下图所示,新增的日期时间规约归属于第一部分:编程规约e9f9f5e36dc512775ee09c59298ec836.png

这一段总计此次新增了7个规约条例,前五条全部是强制类型的:

  1. 日期格式化时,传入pattern中表示年份统一使用小写的y。解读:yyyy表示当天所在的年,而大写的YYYY代表是 week in which year。意思是当天所在的周所属的年份,一周从周日开始,周六结束,只要本周跨年,返回的YYYY就是下一年。

  2. 在日期格式中分清楚大写的 M 和小写的 m,大写的 H 和小写的 h 分别指代的意义。解读:大写M表示月份,小写m表示分钟。大写H表示24小时制,小写h表示12小时制。

  3. 获取当前毫秒数:System.currentTimeMillis(); 而不是 new Date().getTime()。 解读:System.currentTimeMillis()是一个native方法,依赖操作系统,性能更好。

  4. 不允许在程序任何地方中使用:1)java.sql.Date 2)java.sql.Time 3)java.sql.Timestamp。**解读:第 1 个不记录时间,getHours()抛出异常;第 2 个不记录日期,getYear()抛出异常;第 3 个在构造方法 super((time/1000)*1000),fastTime 和 nanos 分开存储秒和纳秒信息。

  5. 不要在程序中写死一年为 365 天,避免在公历闰年时出现日期转换错误或程序逻辑 错误。

后两条是推荐类型的:

  1. 避免公历闰年 2 月问题。闰年的 2 月份有 29 天,一年后的那一天不可能是 2 月 29 日。解读:打个比方,某个任务想一年运行一次,那么cron表达式不要写成:0 0 0 29 2 ?。而应该写成:0 0 0 28 2 ?。前一个表达式实际上是4年才执行一次,后一个表达式才是一年执行一次。

  2. 使用枚举值来指代月份。如果使用数字,注意 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的结果变得更易懂,同时能大大提升排查问题效率,并且还可以针对每个异常码出现的次数做实时监控:3e8b6cd137d36b242222bdea7c847d9b.png

如下图所示,是截取的部分错误码。完整版请下载最新的Java开发手册泰山版,下载地址为https://developer.aliyun.com/topic/java2020:f0d76a0efaa82e1057061359f28f38cd.png

7e68c9a69f0093a159c3be217dc3d876.gif
  • 面试官问:MySQL的自增ID用完了,怎么办?

  • ArrayList插入1000w条数据之后,我怀疑了jvm...

  • 蚂蚁二面,面试官问我零拷贝的实现原理,当场懵了…

df854088ef7c57172b5fa06feef04ab1.png

明天见(。・ω・。)ノ♡
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值