多线程SimpleDateFormat问题
1 2 3 | at java.text.SimpleDateFormat.subParse(SimpleDateFormat.java: 1869 ) 1896 处使用了NumberFormat与DateFormate产生联系使用。but确实作为一个全局变量去使用,于是内部属性也作为全局使用,多线程竞争产生了问题 |
1 2 3 | 优化方案: 1 .使用 1.8 新的DataLocalTime解决这个问题 2 .给每个线程增加个本地变量DateFormat |
1 2 | 方案二: |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | package dubbo.wangbiao.project.ThreadDemo; import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; public class ThreadLocalDemo { private static final SimpleDateFormat sdf = new SimpleDateFormat( "yyy-MM-dd HH:mm:ss" ); private static final ThreadLocal<DateFormat> dateFormatThreadLocal = new ThreadLocal<>(); private static DateFormat getDateFormat() { DateFormat dateFormat = dateFormatThreadLocal.get(); if (dateFormat == null ) { dateFormat = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" ); dateFormatThreadLocal.set(dateFormat); } return dateFormat; } public static Date prase(String dateStr) throws ParseException { Date parse = getDateFormat().parse(dateStr); // sdf.parse(dateStr) return parse; } public static ExecutorService executorService = Executors.newFixedThreadPool( 10 ); public static void main(String[] args) throws InterruptedException { for ( int i = 0 ; i < 20 ; i++) { executorService.submit( new Runnable() { @Override public void run() { try { Thread.sleep( 2000 ); System.out.println(prase( "2020-05-18 20:20:20" )); } catch (InterruptedException | ParseException e) { e.printStackTrace(); } } }); } try { executorService.shutdown(); boolean b = executorService.awaitTermination( 3 , TimeUnit.SECONDS); //b 线程执行时间小于等于设定的3s true //b 线程执行时间打大于等于设定的3s fasle if (!b){ //3S System.out.println( " 到达指定时间,还有线程没执行完,不再等待,关闭线程池!" ); executorService.shutdownNow(); } } catch (InterruptedException e) { executorService.shutdownNow(); e.printStackTrace(); } } } |
本文来自博客园,作者:余生请多指教ANT,转载请注明原文链接:https://www.cnblogs.com/wangbiaohistory/p/16286732.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
2020-05-18 request请求《一》