SimpleDateFormat

******字符串转化成日期的效率比日期转化成字符串的效率要高!!**********************
例如:String checkDate = df.format(new Date()); 
and requ_time > to_date('" + checkDate + " 00:00:00', 'yyyy-mm-dd hh24:mi:ss') 
************************************************************************
这里需要特别说明的是:new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss");这里一定要写成大写的HH,
这样才支持24小时制,如果写成小写的hh那就是12小时制了。这点要特别注意。
***********************************************************************
时间格式如下的:Fri Jun 25 22:54:30 CST 2010 ,就靠这种方式来解析。
public String TransformDateTime(String value){
	SimpleDateFormat format = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss");
		
	Locale locale = Locale.US;
	SimpleDateFormat sdf = new SimpleDateFormat("EEE MMM dd HH:mm:ss z yyyy",locale); 
	Date d;
	String str = null;
	try {
		d = sdf.parse(value);
		Calendar c = Calendar.getInstance(); 
		c.setTime(d); 
		str = format.format(c.getTime());
	} catch (ParseException e) {
		e.printStackTrace();
	}
	return str;
}

 

2. 另外还有一种无法解析的时间:
java.text.ParseException: 
      Unparseable date: "2010-06-25 19:54:30.0"
正在找解决办法...
找到了,直接去截取:

String str = "2010-06-25 19:54:30.0";
str = str.substring(0, str.indexOf("."));
SimpleDateFormat sdf = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss");
sdf.parse(str);

 

 

 

### SimpleDateFormat 的使用与线程安全问题 `SimpleDateFormat` 是 Java 中用于格式化和解析日期时间的常用类,属于 `java.text` 包。它允许开发者将 `Date` 对象转换为字符串表示,或将字符串解析为 `Date` 对象。然而,该类在多线程环境下使用时存在线程安全问题,可能导致数据不一致、抛出异常或解析错误。 #### 1. 基本用法 `SimpleDateFormat` 的基本使用方式如下: ```java SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); Date now = new Date(); String formattedDate = sdf.format(now); System.out.println(formattedDate); Date parsedDate = sdf.parse("2023-10-01 12:00:00"); ``` 该类支持自定义日期格式,常用的格式字符串包括: - `yyyy`:年份 - `MM`:月份 - `dd`:日期 - `HH`:小时(24小时制) - `mm`:分钟 - `ss`:秒 #### 2. 线程安全问题 `SimpleDateFormat` 不是线程安全的,其内部状态在解析或格式化过程中会被修改。如果多个线程共享同一个 `SimpleDateFormat` 实例,则可能导致不可预测的行为,如解析错误、格式错误或抛出异常。 例如,以下代码在并发环境下可能引发问题: ```java SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); ExecutorService executor = Executors.newFixedThreadPool(10); for (int i = 0; i < 100; i++) { final int finalI = i; executor.submit(() -> { String dateStr = sdf.format(new Date(finalI * 1000000000L)); System.out.println(dateStr); }); } ``` 上述代码可能输出不一致的时间字符串,甚至抛出 `ParseException`。 #### 3. 解决方案 为了解决线程安全问题,可以采用以下几种方式: ##### 3.1 每次使用时创建新实例 虽然这种方式可以避免并发问题,但频繁创建对象可能影响性能: ```java public static String formatDate(Date date) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); return sdf.format(date); } ``` ##### 3.2 使用 `ThreadLocal` 变量 通过 `ThreadLocal` 为每个线程维护一个独立的 `SimpleDateFormat` 实例,可以避免并发冲突。必须确保在使用线程池时调用 `remove()` 方法,以防止内存泄漏: ```java private static final ThreadLocal<SimpleDateFormat> sdfHolder = ThreadLocal.withInitial(() -> new SimpleDateFormat("yyyy-MM-dd")); public static String formatDate(Date date) { return sdfHolder.get().format(date); } // 在使用完后调用 remove() sdfHolder.remove(); // 必须实现,否则可能导致内存泄漏 [^1] ``` ##### 3.3 使用 Java 8 的 `DateTimeFormatter` Java 8 引入了新的日期时间 API(`java.time` 包),其中 `DateTimeFormatter` 是线程安全的,推荐用于新项目: ```java DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); LocalDate date = LocalDate.now(); String formatted = date.format(formatter); ``` #### 4. 性能考量 使用 `ThreadLocal` 虽然避免了同步开销,但会增加内存占用。如果线程数量较多,可能会影响整体性能。此外,`ConcurrentHashMap` 等并发结构虽然能减少锁竞争,但仍存在同步开销,不适合替代 `ThreadLocal` 来管理线程局部变量 [^3]。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值