1. 日期时间组件使用

    java.util.Date:实现类,其对象具有时间、日期组件。
    java.util.Calendar:抽象类,其对象具有时间、日期组件。
    java.sql.Date:实现类,其对象具有日期组件。
    java.sql.Time:实现类,其对象具有时间组件。
    java.sql.Timestamp:实现类,其对象具有时间日期组件。
    java.text.DateFormat:抽象类,其对象格式化时间日期。
    java.text.DateFormatSymbols:实现类,其对象为格式化时间日期提供参数。

  2. long currentTime = System.currentTimeMillis(); //获取当前时间戳,从1970-01-01以来的毫秒数
    LOGGER.info("{}", currentTime); java.util.Date utilDate = new java.util.Date(currentTime);
    LOGGER.info("{}|{}", utilDate, utilDate.getTime()); Calendar calendar = Calendar.getInstance(); //除某些特殊地区外,默认等效于new GregorianCalendar()
    calendar.setTimeInMillis(currentTime);
    LOGGER.info("{}", calendar); java.sql.Date sqlDate = new java.sql.Date(currentTime);
    LOGGER.info("{}|{}", sqlDate, sqlDate.getTime()); java.sql.Time sqlTime = new java.sql.Time(currentTime);
    LOGGER.info("{}|{}", sqlTime, sqlTime.getTime()); java.sql.Timestamp sqlTimestamp = new java.sql.Timestamp(currentTime);
    LOGGER.info("{}|{}", sqlTimestamp, sqlTimestamp.getTime());
            DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //默认是SimpleDateFormat
    LOGGER.info("{}", dateFormat.format(utilDate));
    LOGGER.info("{}", dateFormat.parse("2017-05-25 23:00:00"));

    输出:

    1495724884755
    Thu May 25 23:08:04 CST 2017|1495724884755
    java.util.GregorianCalendar[time=1495724884755,...,zone=sun.util.calendar.ZoneInfo[id="Asia/Shanghai"...]
    2017-05-25|1495724884755
    23:08:04|1495724884755
    2017-05-25 23:08:04.755|1495724884755
    2017-05-25 23:08:04
    Thu May 25 23:00:00 CST 2017
  3. java.text.SimpleDateFormat的线程不安全问题
    问题重现:

            //final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
    
            Callable<Date> task = new Callable<Date>() {
    @Override
    public Date call() throws Exception {
    LOGGER.info("executing task...");
    try{
    return new SimpleDateFormat("yyyy-MM-dd").parse("2017-05-25");
    //return format.parse("2017-05-25"); //if use shared SimpleDateFormat, executing result is not expected.
    }catch (Exception ex){
    LOGGER.error("Exception:", ex);
    return new Date(0);
    }
    }
    };
    // pool with 5 threads
    ExecutorService exec = Executors.newFixedThreadPool(5);
    List<Future<Date>> results = new ArrayList<Future<Date>>();
    // perform 10 date conversions
    for (int i = 0; i < 10; i++) {
    LOGGER.info("submit task[{}]", i);
    results.add(exec.submit(task));
    }
    exec.shutdown();
    LOGGER.info("shutdown");
    // look at the results
    DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    for (Future<Date> result : results) {
    LOGGER.info("{}", dateFormat.format(result.get()));
    }
    LOGGER.info("completed");

    输出(使用共享的SimpleDateFormat时,执行结果并不是预期结果):

    submit task[0]
    submit task[1]
    submit task[2]
    executing task...
    submit task[3]
    executing task...
    submit task[4]
    executing task...
    executing task...
    submit task[5]
    executing task...
    submit task[6]
    submit task[7]
    submit task[8]
    submit task[9]
    shutdown
    executing task...
    executing task...
    executing task...
    executing task...
    executing task...
    Exception:
    java.lang.NumberFormatException: multiple points
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1890)
    at sun.misc.FloatingDecimal.parseDouble(FloatingDecimal.java:110)
    at java.lang.Double.parseDouble(Double.java:538)
    at java.text.DigitList.getDouble(DigitList.java:169)
    at java.text.DecimalFormat.parse(DecimalFormat.java:2056)
    at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java:1869)
    at java.text.SimpleDateFormat.parse(SimpleDateFormat.java:1514)
    at java.text.DateFormat.parse(DateFormat.java:364)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:65)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:59)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)
    Exception:
    java.lang.NumberFormatException: empty String
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1842)
    at sun.misc.FloatingDecimal.parseDouble(FloatingDecimal.java:110)
    at java.lang.Double.parseDouble(Double.java:538)
    at java.text.DigitList.getDouble(DigitList.java:169)
    at java.text.DecimalFormat.parse(DecimalFormat.java:2056)
    at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java:1869)
    at java.text.SimpleDateFormat.parse(SimpleDateFormat.java:1514)
    at java.text.DateFormat.parse(DateFormat.java:364)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:65)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:59)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)
    Exception:
    java.lang.NumberFormatException: For input string: "E.2505E2"
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2043)
    at sun.misc.FloatingDecimal.parseDouble(FloatingDecimal.java:110)
    at java.lang.Double.parseDouble(Double.java:538)
    at java.text.DigitList.getDouble(DigitList.java:169)
    at java.text.DecimalFormat.parse(DecimalFormat.java:2056)
    at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java:1869)
    at java.text.SimpleDateFormat.parse(SimpleDateFormat.java:1514)
    at java.text.DateFormat.parse(DateFormat.java:364)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:65)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:59)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)
    Exception:
    java.lang.NumberFormatException: For input string: "E.2505"
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2043)
    at sun.misc.FloatingDecimal.parseDouble(FloatingDecimal.java:110)
    at java.lang.Double.parseDouble(Double.java:538)
    at java.text.DigitList.getDouble(DigitList.java:169)
    at java.text.DecimalFormat.parse(DecimalFormat.java:2056)
    at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java:1869)
    at java.text.SimpleDateFormat.parse(SimpleDateFormat.java:1514)
    at java.text.DateFormat.parse(DateFormat.java:364)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:65)
    at com.liq.DateTimeTest$1.call(DateTimeTest.java:59)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)
    1970-01-01 08:00:00
    1970-01-01 08:00:00
    1970-01-01 08:00:00
    1970-01-01 08:00:00
    2017-05-25 00:00:00
    2017-05-25 00:00:00
    2017-05-25 00:00:00
    2017-05-25 00:00:00
    2017-05-25 00:00:00
    2017-05-25 00:00:00
    completed

    产生原因:
    SimpleDateFormat维护一个共享的Calendar对象,如果共享SimpleDateFomat时这个Calendar也是共享的。由多个线程并发进行操作就会有问题了。

    protected Calendar calendar;

    解决:
    (1)使用局部变量
    (2)使用 ThreadLocal

            final ThreadLocal<DateFormat> df = new ThreadLocal<DateFormat>() {
    @Override
    protected DateFormat initialValue() {
    return new SimpleDateFormat("yyyy-MM-dd");
    }
    };
    //final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); Callable<Date> task = new Callable<Date>() {
    @Override
    public Date call() throws Exception {
    LOGGER.info("executing task...");
    try{
    //return new SimpleDateFormat("yyyy-MM-dd").parse("2017-05-25");
    //return format.parse("2017-05-25"); //if use shared SimpleDateFormat, executing result is not expected.
    return df.get().parse("2017-05-25");
    }catch (Exception ex){
    LOGGER.error("Exception:", ex);
    return new Date(0);
    }
    }
    };

    (3)同步代码块 synchronized(code)
    (4)使用第三方的日期处理函数:比如使用 commons-lang 包中的 FastDateFormat 工具类

参考:

  1. 如何在Java 8中愉快地处理日期和时间
  2. Java中的时间日期处理
  3. 详解SimpleDateFormat的线程安全问题与解决方案
  4. java中关于时间的处理 *
  5. 日历字段之间的转换

Java中的时间处理的更多相关文章

  1. JAVA中的时间操作

    java中的时间操作不外乎这四种情况: 1.获取当前时间 2.获取某个时间的某种格式 3.设置时间 4.时间的运算 好,下面就针对这四种情况,一个一个搞定. 一.获取当前时间 有两种方式可以获得,第一 ...

  2. Java中日期时间API小结

    Java中为处理日期和时间提供了大量的API,确实有把一件简单的事情搞复杂的嫌疑,各种类:Date Time Timestamp Calendar...,但是如果能够看到时间处理的本质就可以轻松hol ...

  3. 1 Java中的时间类型

    总结:sql中的时间转 util的时间直接赋值即可:反过来,必须先吧util下的时间转换成毫秒,再通过sql的构造器生成sql的时间格式. 1 Java中的时间类型 java.sql包下给出三个与数据 ...

  4. Java中的时间日期处理

    程序就是输入——>处理——>输出.对数据的处理是程序员需要着重注意的地方,快速.高效的对数据进行处理时我们的追求.其中,时间日期的处理又尤为重要和平凡,此次,我将把Java中的时间日期处理 ...

  5. java中各种时间格式的转化

    http://www.chinaitpower.com/A/2005-01-14/104881.html 使用java.util.Calendar返回间隔天数         static int g ...

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

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

  7. 【转】Java中本地时间的获取方法--不错

    原文网址:http://highforest.blog.51cto.com/125539/842496/ 熟悉Oracle数据库的人,应该知道:select to_char(sysdate,'yyyy ...

  8. JAVA中Sql时间格式与util时间格式转换

    关于时间格式转化: java.util.Date 与 java.sql.Date 互换 sql是子类 字符串转化成java.util.Date     SimpleDateFormat date =n ...

  9. Java中的时间二三事

    实习过程中对于时间的处理有很多,有的还涉及到从数据库取出时间,所以做一些总结,想到那先写到哪,慢慢补充.    首先最常见的是java.util中的Date类,这个类封装了当前的日期和时间,它实际是计 ...

随机推荐

  1. Ubuntu不能上网解决办法

     一.设置IP.网关.DNS 新安装的Ubuntu系统ifconfig后发现没有ip,所以要设置IP.网关.DNS等,编辑 /etc/networking/interfases sudo vi /et ...

  2. MultiDataTrigger

    MultiDataTrigger是多条件数据触发器 和MltiTrigger是同样的,只不过前者是数据,后者是属性. 这个是基本的使用语法 <MultiDataTrigger> <M ...

  3. 《Servlet和jsp学习指南》 笔记2

    chapter 13 请求和响应的装饰 初步了解Decorator模式: 在不修改一个对象的类的源码的情况下,装饰这个对象的行为. chapter 14 异步处理 异步Servlet和Filter,只 ...

  4. Invalid App Store Icon. The App Store Icon in the asset catalog in 'xxx.app' can’t be transparent nor contain an alpha channel.

    1.向appstore上传应用的时候,报了这样一个错误 ERROR ITMS-90717: "Invalid App Store Icon. The App Store Icon in th ...

  5. MVC,MVP 和 MVVM 的区别之处

    其实我一直以来,虽然做的是前端的工作,但是有一个疑问,就是什么是mvc模式,虽然大概知道,但是具体确实说不上来的的,今天,我就好好总结一下mvc ,mvp,mvvm模式的区别与相同. 1.MVC模式: ...

  6. JS编程模式之初始化分支与惰性初始

    不同的浏览器对于相同或相似的方法可能有不同的实现.这时,您需要依据当前的浏览器的支持方法来选择对应的执行分支.这类分支有可能与很多,因此可能会减缓脚本的执行速度.但非要等到运行时才能分支吗?我们完全可 ...

  7. P4855 MloVtry的idea

    $ \color{#0066ff}{ 题目描述 }$ MloVtry是一个脑洞很大的人,它总会想出一些奇奇怪怪的idea. 可问题是,MloVtry作为一个蒟蒻,很多时候都没办法解决自己提出的问题,所 ...

  8. CentOS修改默认yum源为国内yum镜像源

    修改CentOS默认yum源为mirrors.163.com 1.首先备份系统自带yum源配置文件/etc/yum.repos.d/CentOS-Base.repomv /etc/yum.repos. ...

  9. jenkins官方文档(中文版)

    https://www.w3cschool.cn/jenkins/

  10. linux 检测服务器端口工具

    #nmp# nmap 127.0.0.1 #netstat# netstat -anlp | grep 22 #telnet# 服务器端口即使处于监听状态,但是防火墙iptables屏蔽了该端口,是无 ...