您的位置:

java日期时间解析(java中的日期类)

本文目录一览:

java怎么把日期时间(2018-01-12 00:00:00)转化成(2018-01-12 00:00:00.000+0800)这种格式

C# 可以用 string str1 = DateTime.Now.GetDateTimeFormats()[128]; 或者string str1 = DateTime.Now.GetDateTimeFormats()[129];

public static void main(String[] args) throws Exception{

Date date = new SimpleDateFormat("yyyy-MM-dd").parse("2005-06-09"); 

String now = new SimpleDateFormat("yyyy年MM月dd日").format(date);

System.out.println(now);

}

输出结果:2018年01月12日

扩展资料:

JRE是个运行环境,JDK是个开发环境。因此写Java程序的时候需要JDK,而运行Java程序的时候就需要JRE。而JDK里面已经包含了JRE,因此只要安装了JDK,就可以编辑Java程序,也可以正常运行Java程序。但由于JDK包含了许多与运行无关的内容,占用的空间较大,因此运行普通的Java程序无须安装JDK,而只需要安装JRE即可。

参考资料来源:百度百科-Java

Java中getTime()日期时间计算的问题

确实是一个值得思考的问题。我只发现浅层次的直接原因:精确到秒

这个差异是由 SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 在解析特定日期

1927-12-31 23:54:07到1927-12-31 23:54:08造成的。

这“一秒钟”内发生突变,相差352000毫秒,约5分52秒。

就能解释你“得到的结果就为1940-01-30 23:54:08"的误差

用Calendar和GregorianCalendar类验证,结果相同。

是Java的错误,还是历史规定,没有查到相关资料,深层次的原因不明。

越来越怀疑是bug

java 高手请进!利用DateFormat来解析年月日!

import java.text.DateFormat;

import java.util.Date;

public class Test {

public static void main(String[] args) {

DateFormat df = DateFormat.getInstance();

String[] strings = df.format(new Date()).split(" ")[0].split("-");

for (int i = 0; i strings.length; i++) {

//i=0 年份,i=1 月份,i=2 日可以进行判断

System.out.println(strings[i]);

}

}

}

如何在Java 8中愉快地处理日期和时间

Java 8新增了LocalDate和LocalTime接口,为什么要搞一套全新的处理日期和时间的API?因为旧的java.util.Date实在是太难用了。

java.util.Date月份从0开始,一月是0,十二月是11,变态吧!java.time.LocalDate月份和星期都改成了enum,就不可能再用错了。

java.util.Date和SimpleDateFormatter都不是线程安全的,而LocalDate和LocalTime和最基本的String一样,是不变类型,不但线程安全,而且不能修改。

java.util.Date是一个“万能接口”,它包含日期、时间,还有毫秒数,如果你只想用java.util.Date存储日期,或者只存储时间,那么,只有你知道哪些部分的数据是有用的,哪些部分的数据是不能用的。在新的Java 8中,日期和时间被明确划分为LocalDate和LocalTime,LocalDate无法包含时间,LocalTime无法包含日期。当然,LocalDateTime才能同时包含日期和时间。

新接口更好用的原因是考虑到了日期时间的操作,经常发生往前推或往后推几天的情况。用java.util.Date配合Calendar要写好多代码,而且一般的开发人员还不一定能写对。

LocalDate

看看新的LocalDate怎么用:

// 取当前日期:

LocalDate today = LocalDate.now(); // - 2014-12-24

// 根据年月日取日期,12月就是12:

LocalDate crischristmas = LocalDate.of(2014, 12, 25); // - 2014-12-25

// 根据字符串取:

LocalDate endOfFeb = LocalDate.parse("2014-02-28"); // 严格按照ISO yyyy-MM-dd验证,02写成2都不行,当然也有一个重载方法允许自己定义格式

LocalDate.parse("2014-02-29"); // 无效日期无法通过:DateTimeParseException: Invalid date

日期转换经常遇到,比如:

// 取本月第1天:

LocalDate firstDayOfThisMonth = today.with(TemporalAdjusters.firstDayOfMonth()); // 2014-12-01

// 取本月第2天:

LocalDate secondDayOfThisMonth = today.withDayOfMonth(2); // 2014-12-02

// 取本月最后一天,再也不用计算是28,29,30还是31:

LocalDate lastDayOfThisMonth = today.with(TemporalAdjusters.lastDayOfMonth()); // 2014-12-31

// 取下一天:

LocalDate firstDayOf2015 = lastDayOfThisMonth.plusDays(1); // 变成了2015-01-01

// 取2015年1月第一个周一,这个计算用Calendar要死掉很多脑细胞:

LocalDate firstMondayOf2015 = LocalDate.parse("2015-01-01").with(TemporalAdjusters.firstInMonth(DayOfWeek.MONDAY)); // 2015-01-05

LocalTime

LocalTime只包含时间,以前用java.util.Date怎么才能只表示时间呢?答案是,假装忽略日期。

LocalTime包含毫秒:

LocalTime now = LocalTime.now(); // 11:09:09.240

你可能想清除毫秒数:

LocalTime now = LocalTime.now().withNano(0)); // 11:09:09

构造时间也很简单:

LocalTime zero = LocalTime.of(0, 0, 0); // 00:00:00

LocalTime mid = LocalTime.parse("12:00:00"); // 12:00:00

时间也是按照ISO格式识别,但可以识别以下3种格式:

12:00

12:01:02

12:01:02.345

JDBC

最新JDBC映射将把数据库的日期类型和Java 8的新类型关联起来:

SQL - Java

--------------------------

date - LocalDate

time - LocalTime

timestamp - LocalDateTime

再也不会出现映射到java.util.Date其中日期或时间某些部分为0的情况了。

java中日期时间的实现方法

java中,日期函数的实现方法是通过获取当前时间距离格林治时间1970-1-1 00:00:00的时间差额,获取到时间相差的毫秒数。这个函数在jdk中是直接调用的系统相关的函数获取的,至于这个数据,是通过专门的时钟晶片进行统计的。会有相关的位置存放时间。

如果你想知道更具体的,就参考下JDK中的源码吧,这是最详细的。