用于日期解析的 SimpleDateFormat 的替代方案
我真的需要 SimpleDateFormat 的替代方案,我正在将很多很多 Strig 日期(> 100k)从 JST 转换为 GMT。我遇到的问题是我的代码生成了许多 char[] ,正如我在分析时注意到的那样。对于 150k 日期,我会持续使用 150MB 内存,但这并不是一个真正的选择。谢谢。
SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
sdf.setTimeZone(tz);
try {
Date theResult = sdf.parse(dateToConvert);
SimpleDateFormat rdf = new SimpleDateFormat(resultDateFormat);
rdf.setTimeZone(resultTz);
return rdf.format(theResult);
} catch (ParseException e) {
e.printStackTrace();
}
我无法使用 Joda 时间,所以这对我来说不是一个选择。 :(
I would really need an alternative to SimpleDateFormat, I am converting many-many Strig dates(>100k) from JST to GMT. The problem I have is that my code generates way to many char[] , as I noticed while profiling. For 150k dates, I get constant 150MB of memory used, and its not really an option. Thanks.
SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
sdf.setTimeZone(tz);
try {
Date theResult = sdf.parse(dateToConvert);
SimpleDateFormat rdf = new SimpleDateFormat(resultDateFormat);
rdf.setTimeZone(resultTz);
return rdf.format(theResult);
} catch (ParseException e) {
e.printStackTrace();
}
I can not use Joda time, so that is not an option for me. :(
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
使用乔达时间
use joda-time
作为起点,我会重用这些
SimpleDateFormat
实例,而不是为需要转换的每个日期重新创建它们对。As a starting point, I'd reuse those
SimpleDateFormat
instances rather than re-creating the pair of them for each date that you need to convert.是的,joda time确实有一个很好的API,但是user1143825忘记设置输入时区。
我不能说内存性能,你必须测试它并比较结果。
这应该有效:
Yes, joda time has realy a nice API, but user1143825 forget to set the input timeZone.
And I cannot say about the memory performance, yout have to test it and compare the results.
This should work:
使用java
使用joda库时间转换
这个库提高了我的代码速度性能
使用java代码14991毫秒
使用 joda 库 1668 毫秒
using java
Using joda Library time conversion
this library is improved my code speed performance
using java code 14991 ms
using joda library 1668 ms
您是否有特定的理由认为
SimpleDateFormat
在解析日期方面效率低下?除非您的日期具有非常具体的特征,可以进行某种优化,否则我认为 JDK 类将完成合理的工作。也就是说,假设您的日期并不完全不同(不太可能有 100k),您可以研究缓存 - 使用传入的
String
和Date
填充地图代码>出来了。这可能会大大减少所需的解析量;它可能会也可能不会导致明显的加速/内存增益,具体取决于现有的特性。顺便说一句,每次创建两个新的 SimpleDateFormat 可能效率非常低。为什么不在加载类时创建一次这些实例(除非格式按行更改)?如果 SDF 的内部结构在第一次运行时涉及大量 char[] 分配,那么这本身可能会解决您的问题。 (但请记住,奇怪的日期格式不是线程安全的,因此如果同时使用解析类,您可能需要 ThreadLocal)。
Do you have a particular reason to assume that
SimpleDateFormat
is inefficient at parsing dates? Unless your dates have a very specific characteristic to them that lends itself to a certain optimisation, I would have thought that the JDK class will do a reasonable job of it.That said, on the assumption that your dates aren't all distinct (unlikely with 100k), you could look into caching - populate a map with the
String
being passed in and theDate
coming out. This will likely greatly reduce the amount of parsing required; it may or may not result in a noticeable speed-up/memory gain depending on the existing characteristics.As an aside, creating two new SimpleDateFormats each time is likely to be very inefficient. Why not create these instances once when the class is loaded (unless the format changes by the line)? This might solve your problem in itself, if the internals of the SDF are such that it involves a lot of
char[]
allocation on its first run. (Remember that bizarrely date formats aren't thread-safe, though, so you might want aThreadLocal<DateFormat>
if your parsing class is used concurrently).