文档章节

DateFormat 线程不安全

囚兔
 囚兔
发布于 2016/05/11 09:48
字数 404
阅读 147
收藏 1

一、测试

测试代码如下: 

    private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

    public static void main(String[] args) throws ParseException{
        for (int i = 0; i < 2; i++) {
            Thread t = new Thread(new TestRunnable(), "t-" + i);
            t.start();
        }
    }

    static class TestRunnable implements Runnable {

        @Override
        public void run() {
            while(true) {

                long dateTime = 0;
                String dateStr = "2016-05-09 08:21:02";

                try{
                    Date dt = sdf.parse(dateStr);
                    dateTime = dt.getTime();
                } catch(Exception e){
                    e.printStackTrace();
                }

                if(dateTime < 0) {
                    System.out.println(dateTime);
                }
            }
        }
    }

输出结果:

java.lang.NumberFormatException: For input string: ""
	at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
	at java.lang.Long.parseLong(Long.java:453)
	at java.lang.Long.parseLong(Long.java:483)
	at java.text.DigitList.getLong(DigitList.java:194)
	at java.text.DecimalFormat.parse(DecimalFormat.java:1316)
	at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java:2088)
	at java.text.SimpleDateFormat.parse(SimpleDateFormat.java:1455)
	at java.text.DateFormat.parse(DateFormat.java:355)
-125744830738000
-61916917138000
-61916917138000
	at com.tiza.ngp.rp.sanhui.util.Utils$TestRunnable.run(Utils.java:214)
	at java.lang.Thread.run(Thread.java:745)
java.lang.NumberFormatException: For input string: ""
	at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
	at java.lang.Long.parseLong(Long.java:453)

结果要么抛异常,要么结果为错误的负值。

二、简单分析

public abstract class DateFormat extends Format {

    /**
     * The {@link Calendar} instance used for calculating the date-time fields
     * and the instant of time. This field is used for both formatting and
     * parsing.
     *
     * <p>Subclasses should initialize this field to a {@link Calendar}
     * appropriate for the {@link Locale} associated with this
     * <code>DateFormat</code>.
     * @serial
     */
    protected Calendar calendar;

    ...
}

DateFormat类使用了Calendar对象来维护parse和format过程中的日期时间值,当多线程同时使用同一个DateFormat对象,也就是多线程同时使用同一个Calendar对象来维护parse或format过程的日期时间值,必定会发生错乱。

引用Java api文档:

Synchronization

Date formats are not synchronized. It is recommended to create separate format instances for each thread. If multiple threads access a format concurrently, it must be synchronized externally.

三、解决方案

使用中要么为每个线程创建一个DateFormat实例,要么对其外部加锁。

 

© 著作权归作者所有

共有 人打赏支持
囚兔

囚兔

粉丝 39
博文 82
码字总数 46066
作品 1
南京
程序员
有关Java的日期处理的一些杂记

有关Java的日期处理的一些杂记 在企业应用开发中,经常会遇到日期的相关处理,说实话JDK自带的日期方法很难用。就我个人而言我一般都会采用joda-time来替代JDK自身的日期。 这篇文章是杂记,...

泳泳啊泳泳
01/07
0
0
深入理解Java:SimpleDateFormat安全的时间格式化

想必大家对SimpleDateFormat并不陌生。SimpleDateFormat 是 Java 中一个非常常用的类,该类用来对日期字符串进行解析和格式化输出,但如果使用不小心会导致非常微妙和难以调试的问题,因为 ...

长平狐
2013/06/17
86
0
DateFormat 的多线程问题

DateFormat不是线程安全的,在jdk中是这么写的: SynchronizationDate formats are not synchronized. It is recommended to create separate format instances for each thread. If multip......

rain
2012/11/14
0
0
SimpleDateFormat的线程安全问题

SimpleDateFormat在进行日期格式转换时用的很多,但是 DateFormat 和 SimpleDateFormat 类不都是线程安全的,在多线程环境下调用 format() 和 parse() 方法应该使用同步代码来避免问题 * <p...

十二缸帕萨特
2015/10/16
392
0
线程安全的DateFormat工具类

使用threadLocal包装DateFormat(太复杂,不推荐) 使用org.apache.commons.lang3.time.DateFormatUtils下的方法(推荐) 注意:该类使用了org.apache.commons.lang3.time.FastDateFormat(是...

问题达人
2016/12/13
19
0

没有更多内容

加载失败,请刷新页面

加载更多

【转载】Linux升级安装GCC

https://itbilu.com/linux/management/V1vdnt9ll.html

goodman_fz
39分钟前
2
0
20.20 告警系统主脚本~20.22 告警系统监控项目

告警系统主脚本 main.sh内容 #!/bin/bash#Written by aming.# 是否发送邮件的开关export send=1# 过滤ip地址export addr=`/sbin/ifconfig |grep -A1 "ens33: "|awk '/inet/ {...

洗香香
42分钟前
2
0
07-利用思维导图梳理JavaSE-包与访问控制权限

07-利用思维导图梳理JavaSE-包与访问控制权限 主要内容 1.包的概念及使用 1.1.包的概念 1.2.包的作用 1.3.需要注意的问题 1.4.包的引用 2.系统常见包 2.1.java.lang包 2.2.java.io包 2.3.ja...

飞鱼说编程
43分钟前
2
0
【挑战剑指offer】系列02:替换空格

本系列的算法原题来自于“牛客网-剑指offer”,写这个板块,不仅仅是解决算法问题本身,更是手动提高难度、自行变式,思考更多的解决方案,以带给自己一些启发。 1. 【替换空格】原始题目 算...

LinkedBear
58分钟前
1
0
Win10内部更新:警告用户别用chrome和Firefox

简评:别和 Chrome 和 Firefox 约行不,我 Edge 明明更美、屁股更翘、更性感。。。 微软正在测试 Windows 10 的一个更新:警告用户不要安装 Chrome 和 Firefox。是测试人员发现的这个新警告,...

极光推送
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部