模拟场景
针对于常用的操作API,比如流操作(字符流、字节流),时间操作等,仅仅了解概念性的定义终究是无法了解该类的用途和使用方式;这种情况在使用的时候便一脸茫然,脑海中映射不到对应的知识点。
本篇博客将通过一个简单的应用场景来体会这两个类的使用。

项目开发阶段,有一个关于下单发货的需求:
如果今天下午三点前进行下单,那么发货时间是明天
如果今天下午三点后机型下单,那么发货时间是后天
如果被确定的发货时间是周日的话,那么在此时间上再加一天为最终发货时间

牛刀小试( java 原始)
整体逻辑:主函数创建下单时间,调用函数进行逻辑判断,返回最终的发货时间。
整理代码如下(主函数不在列举):

private static Date sendDateTime(String orderTime) throws ParseException {
/**
* 1:
* 1.1:实例化一个date为今天下午三点
* 2:判断date是否大于今天下午三点,定义一个发货时间
* 2.1:如果不大于的话,则发货时间是明天
* 2.2:如果大于的话,则发货时间是后天
* 3:判断发货时间是否是周日,
* 3.1:如果不大于的话,则发货时间不变
* 3.2:如果大于的话,则发货时间再加一天
*
*/
// 获取订单时间
DateFormat format=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date orderDateTime = format.parse(orderTime); // 获取今天下午三点,这里计算有问题
Calendar equalInstance = Calendar.getInstance();
equalInstance.set(Calendar.HOUR_OF_DAY,15);
equalInstance.set(Calendar.MINUTE, 0);
equalInstance.set(Calendar.SECOND, 0);
Date orderEqualTime = equalInstance.getTime(); // 创建预下单时间
Calendar calendar = Calendar.getInstance();
calendar.setTime(orderDateTime); // 判断订单时间是否大于今天下午三点
boolean isMoreThan = orderDateTime.after(orderEqualTime);
if(isMoreThan){
// 发货时间是后天(订单时间加两天)
calendar.add(Calendar.DATE,2);
}else{
// 发货时间是明天(订单时间加一天)
calendar.add(Calendar.DATE,1);
}
Date preShipTime = calendar.getTime();
return skipTime(preShipTime);
}
private static Date skipTime(Date date){
Calendar instance = Calendar.getInstance();
instance.setTime(date);
// 外国的习俗是周末是一周的第一天,在java8以及JodaTime中已经恢复成正常的周末顺序
int preWeekDay = instance.get(Calendar.DAY_OF_WEEK);
// 因为是今天,所以我拿周二来判断,而不是周日
if(preWeekDay==Calendar.SUNDAY){
instance.add(Calendar.DATE,1);
}
return instance.getTime();
}
    private static DateTime calculateTime(String orderTime) {
// 获取当前订单时间
DateTimeFormatter dateTimeFormatter = DateTimeFormat.forPattern("yyyy-MM-dd HH:mm:ss");
DateTime orderDateTime = dateTimeFormatter.parseDateTime(orderTime);
// 创建今天下午三点的时间
DateTime orderEqualTime = orderDateTime.withHourOfDay(15).withMinuteOfHour(0).withSecondOfMinute(0);
// DateTime orderEqualTime = new DateTime(2019, 11, 10, 15, 0, 0, 0); // 创建预发货时间
DateTime preSkipDateTime=orderEqualTime.isAfter(orderDateTime)?orderDateTime.plusDays(1):orderDateTime.plusDays(2); return isTuesday(preSkipDateTime);
} private static DateTime isTuesday(DateTime preSkipDateTime) {
// 获取预发货时间位于星期几
int dayOfWeek = preSkipDateTime.getDayOfWeek();
return (dayOfWeek != DateTimeConstants.SUNDAY) ? preSkipDateTime : preSkipDateTime.plusDays(1);
}
版本升级(java 8)
private static LocalDateTime calculateTime(String orderTime){
/**
* 1:将字符串转变为date
* 1.1:实例化一个date为今天下午三点
* 2:判断date是否大于今天下午三点,定义一个发货时间
* 2.1:如果不大于的话,则发货时间是明天
* 2.2:如果大于的话,则发货时间是后天
* 3:判断发货时间是否是周日,
* 3.1:如果不大于的话,则发货时间不变
* 3.2:如果大于的话,则发货时间再加一天
*
*/
// 获取订单时间
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
LocalDateTime orderDateTime = LocalDateTime.parse(orderTime, dateTimeFormatter); // 设置今天下午三点
LocalDateTime orderEqualTime= orderDateTime.withHour(15).withMinute(0).withSecond(0);
// LocalDateTime orderEqualTime = LocalDateTime.of(LocalDate.now(), LocalTime.of(15, 0, 0)); // 判断订单时间是否在下午三点之前,如果是的话,设定发货时间是明天,否则的话是后天
// 定义一个预发货时间
LocalDateTime preSkipDateTime=orderEqualTime.isAfter(orderDateTime)?orderDateTime.plusDays(1):orderDateTime.plusDays(2);
return isSunday(preSkipDateTime);
} /**
* 判断预下单时间是否周末
* @param preSendDateTime
* @return
*/
private static LocalDateTime isSunday(LocalDateTime preSendDateTime){
// 获取预下单时间是星期几
DayOfWeek dayOfWeek = preSendDateTime.getDayOfWeek();
// 定义发货时间
return (dayOfWeek!=DayOfWeek.SUNDAY)?preSendDateTime:preSendDateTime.plusDays(1);
}

心得体会
想必通过这三次代码的迭代和重构,大家已经看到的哪些时间类API功能强大;当然他们之中的区别绝不是表面使用方便那么简单,第一种利用Data和Calendar的方式目前不推荐使用,因为SimpleDateFormat作为一个非线程安全的类,被当做了共享变量在多个线程中进行使用,这就出现了线程安全问题。推荐大家使用第二个或者是第三种,第二种是在Java8出现之间一直作为Java时间类的替代品所使用的,通过代码即表明功能依旧很强大。

原文链接:https://blog.csdn.net/zhao1955/article/details/103044685

Java中常见时间类的使用的更多相关文章

  1. JAVA中常见异常类

    1. java.lang.nullpointerexception 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对 ...

  2. Java中六大时间类的使用和区别

    关于java中六个时间类的使用和区别 java.util.Date java.sql.Date  java.sql.Time  java.sql.Timestamp java.text.SimpleD ...

  3. Java中Date时间类

    Date:表示特定的瞬间,精确到毫秒. 构造方法: Date():根据当前的默认毫秒值创建日期对象 Date(long date):根据给定的毫秒值创建日期对象 public static void ...

  4. Java 中常见的 final 类

    Java 中常见的 final 类 java.lang 包 public final class Boolean extends Object implements Serializable, Com ...

  5. Java基础-JAVA中常见的数据结构介绍

    Java基础-JAVA中常见的数据结构介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是数据结构 答:数据结构是指数据存储的组织方式.大致上分为线性表.栈(Stack) ...

  6. java中常见的六种线程池详解

    之前我们介绍了线程池的四种拒绝策略,了解了线程池参数的含义,那么今天我们来聊聊Java 中常见的几种线程池,以及在jdk7 加入的 ForkJoin 新型线程池 首先我们列出Java 中的六种线程池如 ...

  7. JAVA中常见的阻塞队列详解

    在之前的线程池的介绍中我们看到了很多阻塞队列,这篇文章我们主要来说说阻塞队列的事. 阻塞队列也就是 BlockingQueue ,这个类是一个接 口,同时继承了 Queue 接口,这两个接口都是在JD ...

  8. 关于Java中的String类知识点小总结

    Java中的String类知识点 前言 在 Java 中字符串属于对象,Java 提供了 String 类来创建和操作字符串. 如何创建字符串 最简单的方式 String str = "he ...

  9. java中的File类

    File类 java中的File类其实和文件并没有多大关系,它更像一个对文件路径描述的类.它即可以代表某个路径下的特定文件,也可以用来表示该路径的下的所有文件,所以我们不要被它的表象所迷惑.对文件的真 ...

随机推荐

  1. java8中计算两个日期时间LocalDateTime的时间差,格式化成xx年yy月zz日aa时bb分cc秒

    原则上应该适用Period来计算,因为他是专门为这种需求设计的.当时他只能计算到两个时间差的,年月日 传入参数Period.between(LocalDate,LocalDate) 这里是计算两个Lo ...

  2. (七)UML之用例图

    用例图主要用来描述“用户.需求.系统功能单元”之间的关系.它展示了一个外部用户能够观察到的系统功能模型图. [用途]:帮助开发团队以一种可视化的方式理解系统的功能需求. 用例图所包含的元素如下: 1. ...

  3. 【Leetcode_easy】687. Longest Univalue Path

    problem 687. Longest Univalue Path 参考 1. Leetcode_easy_687. Longest Univalue Path; 2. Grandyang; 完

  4. Hibrtnate组件映射

    Component映射 在hibernate中Component映射采用<component>标签即可 Component是某个实体的逻辑组成部分,它与实体类的主要差别在于,它没有oidC ...

  5. JMETER安装教程

    jmeter的安装教程 1:安装jdk并且配置好环境变量,此处就不做赘述(前面的文档中有) 2:下载jmeter文件和jmeter的插件文件 JMeter:http://jmeter.apache.o ...

  6. 【c# 学习笔记】密封类

    密封类不可以被另外一个类继承,如果强行在代码中继承一个密封类,编译时就会产生错误. c#使用sealed关键字来定义密封类,如下: //定义密封类 public sealed class Sealed ...

  7. 【FFMPEG】I,P,B帧和PTS,DTS时间戳的关系

    FFmpeg里有两种时间戳:DTS(Decoding Time Stamp)和PTS(Presentation Time Stamp). 顾名思义,前者是解码的时间,后者是显示的时间.要仔细理解这两个 ...

  8. JAVA 字节码操作利器javassist

    引用:http://blog.csdn.net/hudashi/article/details/50884742 http://blog.csdn.net/haitaofeiyang/article/ ...

  9. OS选择题练习

    一.死锁 1.设系统中有n个进程并发,共同竞争资源X,且每个进程都需要m个X资源,为使该系统不会发生死锁,资源X的数量至少为() A.n*m+1 B.n*m+n C.n*m+1-n   D.无法预计 ...

  10. 工作总结--CTO(张王岩)IO的正式使用

    4个抽象类 InputStreawm int read()  void close() OutputStream void write(int) void flush() void close() R ...