37、一篇文章学习 Java 中的日期相关类(Date 和 Calendar),非常常用

简介: 37、一篇文章学习 Java 中的日期相关类(Date 和 Calendar),非常常用


一、认识 Date

📝 java.util.Date 是开发中常用的日期处理

🍀 日期处理在开发中很常用。一般来说,每一张数据库表都应该存在一个 create_time 字段,用于表示这张表的某条数据的插入时间

🍀 若用 MySQL 的 CURRENT_TIMESTAMP(当前时间戳)的话,当遇到低版本的 MySQL 的话就会报错了

🍀 所以,可通过 Java 的 java.util.Date 类给表的 create_time 字段提供值

📝 一个没有给构造方法传参数的 Date 对象表示的是创建该 Date 对象时的时间⏰(包括:年、月、日、时、分、秒、星期 …)

public class TestDemo {
    public static void main(String[] args) {
        Date date = new Date();
        // output: Mon Oct 24 03:00:48 CST 2022
        System.out.println(date);
    }
}

🍀 打印出来的时间⏰非常国际范(不符合中国人的阅读习惯😀)

🍀 Mon:表示星期一

🍀 Oct:表示十月份

🍀 CST:China Standard Time(中国标准时间)

📝 给 Date 类的构造方法传一个 long 类型的参数的话,表示的是:格林尼治时间的1970年1月1日0时0分0秒加上参数毫秒后的时间

public class TestDemo {
    public static void main(String[] args) {
        Date date = new Date(1000);
        // Thu Jan 01 08:00:01 CST 1970
        System.out.println(date);
    }
}

🍀 上面的代码:传入【1000】作为 Date 类的参数,表示的是格林尼治时间的1970年1月1日0时0分0秒1000毫秒后的时间

🍀 1000毫秒等于1秒,所以是:Thu Jan 01 08:00:01 CST 1970

🍀 打印出来的时间是08,因为中国比格林尼治时间快八个小时(时区)

📝 System.currentTimeMillis()返回的是从格林尼治时间的1970年1月1日0时0分0秒到此时此刻所经历的毫秒数(即时间戳)

public class TestDemo {
    public static void main(String[] args) {
        Date d1 = new Date(System.currentTimeMillis());
        Date d2 = new Date();
        // true: d1 和 d2 表示的是同一个时间
        System.out.println(d1.equals(d2));
    }
}

二、Date 常用方法

public class TestDemo {
    public static void main(String[] args) {
        Date d1 = new Date(System.currentTimeMillis());
        Date d2 = new Date();
        // 设置毫秒数
        d1.setTime(1000);
        d2.setTime(2000);
        // 获取毫秒数
        long d1Mills = d1.getTime();
        long d2Mills = d2.getTime();
        // 比较时间
        boolean ret1 = d2.after(d1); // output: true
        boolean ret2 = d1.before(d2); // output: true
        int ret3 = d1.compareTo(d2); // output: -1
    }
}

三、SimpleDateFormat

📝 java.text.SimpleDateFormat常用来做日期的格式化处理(重要)

public class TestDemo {
    public static void main(String[] args) throws ParseException {
        String s = "2011-08-13 19:35:38";
        String e = "2023-08-13 19:35:38";
        System.out.println(GqDates.inThisTimeRange(s, e));
    }
}
class GqDates {
    public static final String YMDHMS_24_DATE_STR = "yyy-MM-dd HH:mm:ss";
    public static final String YMDHMS_12_DATE_STR = "yyy-MM-dd hh:mm:ss";
    public static final String MILL_DATE_STR = "yyyyMMddHHmmssS";
    /**
     * 生成毫秒时间字符串(如 20221024034702656)
     * 该字符串可简单看做一个【唯一字符串】
     */
    public static String curMillTimeStr() {
        return createCurTimeString(MILL_DATE_STR);
    }
    /**
     * 生成时间字符串(二十四小时制)
     */
    public static String curTimeStr24() {
        return createCurTimeString(YMDHMS_24_DATE_STR);
    }
    /**
     * 生成时间字符串(十二小时制)
     */
    public static String curTimeStr12() {
        return createCurTimeString(YMDHMS_12_DATE_STR);
    }
    /**
     * 生成指定格式的, 当前时间的字符串
     *
     * @param pattern 日期格式
     */
    public static String createCurTimeString(String pattern) {
        SimpleDateFormat sdf = new SimpleDateFormat(pattern);
        return sdf.format(new Date());
    }
    /**
     * 把指定格式的日期字符串转换为日期对象 (Date)
     *
     * @param str     日期字符串
     * @param pattern 日期格式
     * @return 日期对象
     */
    public static Date string2DateObj(String str, String pattern) throws ParseException {
        return new SimpleDateFormat(pattern).parse(str);
    }
    /**
     * 获取某个时间字符串的毫秒值(时间戳)
     * 时间戳查询网:http://shijianchuo.wiicha.com/
     */
    public static long getMills(String dateStr, String pattern) throws ParseException {
        Date date = string2DateObj(dateStr, pattern);
        return date.getTime();
    }
    /**
     * 判断当前时间是否在某段时间范围内
     */
    public static boolean inThisTimeRange(String start, String end) {
        try {
            long s = getMills(start, YMDHMS_24_DATE_STR);
            long e = getMills(end, YMDHMS_24_DATE_STR);
            long cur = System.currentTimeMillis();
            return s < cur && cur < e;
        } catch (ParseException e) {
            e.printStackTrace();
            return false;
        }
    }
}

四、Calendar

📝 java.util.Calendar 也是开发中经常使用的日期处理

📝 它的功能更加丰富(Date 中很多过期的方法都迁移到了 Calendar 中)

public class TestDemo {
    public static void main(String[] args) {
        // Calendar 的实例中包含了当前时间的信息
        Calendar calendar = Calendar.getInstance();
        // 当前年
        int year = calendar.get(Calendar.YEAR);
        // 当前月【取值范围[0, 11], 0是一月, 11是十二月
        int month = calendar.get(Calendar.MONTH);
        int dayOfMonth = calendar.get(Calendar.DAY_OF_MONTH);
        int week = calendar.get(Calendar.DAY_OF_WEEK);
        int dayOfYear = calendar.get(Calendar.DAY_OF_YEAR);
        int hour = calendar.get(Calendar.HOUR);
        int minute = calendar.get(Calendar.MINUTE);
        int second = calendar.get(Calendar.SECOND);
        int mill = calendar.get(Calendar.MILLISECOND);
    }
}

五、Calendar 常用方法

public class TestDemo {
    public static void main(String[] args) {
        Calendar c = Calendar.getInstance();
        // 2022 8 8
        c.set(2022, Calendar.SEPTEMBER, 8);
        // 2022 8 10
        c.add(Calendar.DAY_OF_MONTH, 2);
        // 2022 10 10
        c.add(Calendar.MONTH, 2);
        // 获取 Date 对象
        c.getTime();
        // 设置 Date 对象
        c.setTime(new Date());
        // 设置毫秒数
        c.setTimeInMillis(System.currentTimeMillis());
        // 获取毫秒数
        c.getTimeInMillis();
    }
}
相关文章
|
6天前
|
安全 Java 编译器
JAVA泛型类的使用(二)
接上一篇继续介绍Java泛型的高级特性。3. **编译时类型检查**:尽管运行时发生类型擦除,编译器会在编译阶段进行严格类型检查,并允许通过`extends`关键字对类型参数进行约束,确保类型安全。4. **桥方法**:为保证多态性,编译器会生成桥方法以处理类型擦除带来的问题。5. **运行时获取泛型信息**:虽然泛型信息在运行时被擦除,但可通过反射机制部分恢复这些信息,例如使用`ParameterizedType`来获取泛型参数的实际类型。
|
6天前
|
安全 Java 编译器
JAVA泛型类的使用(一)
Java 泛型类是 JDK 5.0 引入的重要特性,提供编译时类型安全检测,增强代码可读性和可维护性。通过定义泛型类如 `Box&lt;T&gt;`,允许使用类型参数。其核心原理是类型擦除,即编译时将泛型类型替换为边界类型(通常是 Object),确保与旧版本兼容并优化性能。例如,`Box&lt;T&gt;` 编译后变为 `Box&lt;Object&gt;`,从而实现无缝交互和减少内存开销。
|
2月前
|
JSON Java Apache
Java基础-常用API-Object类
继承是面向对象编程的重要特性,允许从已有类派生新类。Java采用单继承机制,默认所有类继承自Object类。Object类提供了多个常用方法,如`clone()`用于复制对象,`equals()`判断对象是否相等,`hashCode()`计算哈希码,`toString()`返回对象的字符串表示,`wait()`、`notify()`和`notifyAll()`用于线程同步,`finalize()`在对象被垃圾回收时调用。掌握这些方法有助于更好地理解和使用Java中的对象行为。
|
3月前
|
Java 开发者
在 Java 中,一个类可以实现多个接口吗?
这是 Java 面向对象编程的一个重要特性,它提供了极大的灵活性和扩展性。
200 58
|
6月前
|
Java 开发者
奇迹时刻!探索 Java 多线程的奇幻之旅:Thread 类和 Runnable 接口的惊人对决
【8月更文挑战第13天】Java的多线程特性能显著提升程序性能与响应性。本文通过示例代码详细解析了两种核心实现方式:Thread类与Runnable接口。Thread类适用于简单场景,直接定义线程行为;Runnable接口则更适合复杂的项目结构,尤其在需要继承其他类时,能保持代码的清晰与模块化。理解两者差异有助于开发者在实际应用中做出合理选择,构建高效稳定的多线程程序。
76 7
|
4月前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
66 3
|
4月前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
68 2
|
4月前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
71 1
|
6月前
|
Oracle 安全 Java
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
|
6月前
|
安全 Java
【Java集合类面试三】、Map接口有哪些实现类?
这篇文章介绍了Java中Map接口的几种常用实现类:HashMap、LinkedHashMap、TreeMap和ConcurrentHashMap,以及它们适用的不同场景和线程安全性。

热门文章

最新文章