localtime转date,LocalTime

http://www.itjxue.com  2023-01-21 04:55  来源:未知  点击次数: 

java8新增了localdate和localtim,要如何处理日期和时间?

JDK8中,新增了三个类,用以处理时间。

LocalDate专门处理日期,LocalTime专门处理时间,LocalDateTime包含了日期和时间,而且对于很多复杂的问题,都提供了现成的方法,比如:获取2017年12月的第一个周一,这样的处理,在以前,是很复杂的,而现在,只需要一行代码即可。(使用前,需要将JDK升级到1.8)

下面,简单了记录了这两个类的一些常见用法:

[java]?view plain?copy

package?test;

import?java.time.DayOfWeek;

import?java.time.LocalDate;

import?java.time.LocalDateTime;

import?java.time.LocalTime;

import?java.time.temporal.TemporalAdjusters;

import?java.util.Calendar;

/**

*?Created?by?lightClouds917

*?Date?2017/11/6

*?Description:Java8中处理时间和日期的类

*

SQL??-?Java

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

date?-?LocalDate

time?-?LocalTime

timestamp?-?LocalDateTime

*/

public?class?DateTest2?{

public?static?void?main(String[]?args){

test1(); ? ? ?

test2();

Calendar?calendar?=?Calendar.getInstance();

System.out.println(calendar.getTime());

}

/**

*?处理日期?LocalDate

*/

public?static?void?test1(){

//获取当前日期???2017-11-06

LocalDate?today?=?LocalDate.now();

System.out.println(today); ?

//构造日期???2017-10-08

LocalDate?today2?=?LocalDate.of(2017,10,8);

System.out.println(today2);

//构造日期???2017-02-22????字符串严格按照yyyy-MM-dd ? ? ?

LocalDate?today3?=?LocalDate.parse("2017-02-22");

System.out.println(today3);

//本月第一天??2017-11-01

LocalDate?firstDayOfMonth?=?today.with(TemporalAdjusters.firstDayOfMonth());

System.out.println(firstDayOfMonth);

//本月第二天??2017-11-02???第n天

LocalDate?secondDayOfMonth?=?today.withDayOfMonth(2);

System.out.println(secondDayOfMonth);

//本月最后一天?2017-02-28??方便解决任何年份的二月份多少天

LocalDate?lastDayOfMonth?=?today3.with(TemporalAdjusters.lastDayOfMonth());

System.out.println(lastDayOfMonth);

//获取2017年12月的第一个周一???2017-12-04 ?

LocalDate?firstDayOf201712?=?LocalDate.parse("2017-12-01").with(TemporalAdjusters.firstInMonth(DayOfWeek.MONDAY));

System.out.println(firstDayOf201712);

}

/**

*?处理时间??LocalTime

*/

public?static?void?test2(){

//获取当前时间??含有毫秒值??17:18:41.571

LocalTime?now?=?LocalTime.now();

System.out.println(now);

//获取当前时间???去掉毫秒值???17:45:41

LocalTime?now1?=?LocalTime.now().withNano(0);

System.out.println(now1);

//00:46:46.651??提供了把时分秒都设为0的方法

LocalTime?now2?=?LocalTime.now().withHour(0);

System.out.println(now2);

//构造时间??00:20:55 ?

LocalTime?time1?=?LocalTime.of(0,20,55);

System.out.println(time1);

//构造时间??05:43:22

LocalTime?time2?=?LocalTime.parse("05:43:22");

System.out.println(time2);

//标准时间?2017-11-06T17:53:15.930

LocalDateTime?lt?=?LocalDateTime.now();

System.out.println(lt);

}

}

java中utc时间怎么转换为本地时间

JAVA中将UTC时间转换为本地时间的方法,其他的时区转换与此类似。

public static String utc2Local(String utcTime, String utcTimePatten,

String localTimePatten) {

SimpleDateFormat utcFormater = new SimpleDateFormat(utcTimePatten);

utcFormater.setTimeZone(TimeZone.getTimeZone("UTC"));//时区定义并进行时间获取

Date gpsUTCDate = null;

try {

gpsUTCDate = utcFormater.parse(utcTime);

} catch (ParseException e) {

e.printStackTrace();

}

SimpleDateFormat localFormater = new SimpleDateFormat(localTimePatten);

localFormater.setTimeZone(TimeZone.getDefault());

String localTime = localFormater.format(gpsUTCDate.getTime());

return localTime;

}

C语言获取系统时间

需要利用C语言的时间函数time和localtime,具体说明如下:

一、函数接口介绍:

1、time函数。

形式为time_t time (time_t *__timer);

其中time_t为time.h定义的结构体,一般为长整型。

这个函数会获取当前时间,并返回。 如果参数__timer非空,会存储相同值到__timer指向的内存中。

time函数返回的为unix时间戳,即从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒。

由于是秒作为单位的,所以这并不是习惯上的时间,要转为习惯上的年月日时间形式就需要另外一个函数了。

2、localtime函数。

形式为struct tm *localtime (const time_t *__timer);

其中tm为一个结构体,包含了年月日时分秒等信息。

这种结构是适合用来输出的。

如何在java8中愉快地处理日期和时间java8新增了localdate和localtim

怎么才能愉快地处理日期和时间?答案是:立刻升级到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的情况了。

iOS 时间戳在不同时区转换问题

一、给定一个10位时间戳,转成不同时区的日期

//给定一个时间戳

NSString?*test =?@"1652861974”;

//转成北京时区下的日期

NSDateFormatter?*beijingFormatter = [[NSDateFormatter?alloc]?init];

[beijingFormatter?setDateFormat:@"yyyy-MM-dd HH:mm:ss"];

NSTimeZone?*beijingZone = [NSTimeZone?timeZoneWithAbbreviation:@"GMT+0800"];

[beijingFormatter?setTimeZone:beijingZone];

//转成手机系统设置的时区(纽约)下的日期

NSDateFormatter?*localFormatter = [[NSDateFormatter?alloc]?init];

[localFormatter?setDateFormat:@"yyyy-MM-dd HH:mm:ss"];

NSTimeZone?*localZone = [NSTimeZone?systemTimeZone];//当前手机设置的是纽约时区

[localFormatter?setTimeZone:localZone];

?NSDate* testDate = [NSDate?dateWithTimeIntervalSince1970:[test?longLongValue]];

NSString* beijingDateString = [beijingFormatter stringFromDate:?testDate];//北京时区下的日期字符串 :“2022-05-18 16:19:34”

NSString* localTimeString = [localFormatter stringFromDate:?testDate];// 换成本地(纽约)时间:2022-05-18 04:19:34

NSLog(@"服务器返回北京时间:%@ 转换成本地时区时间:%@ ",?beijingDateString,?localTimeString);

结果打印: 服务器返回北京时间:2022-05-18 16:19:34 转换成本地时区时间:2022-05-18 04:19:34

二、反向验证同一时刻下世界在不同时区的日期返回的时间戳是相同的:

北京时区日期: 2022-05-18 16:19:34 ( 以上的beijingDateString对应的 )

纽约时区日期: 2022-05-18 04:19:34( 以上的localTimeString对应的 )

NSDate?*beiDate = [beijingFormatter?dateFromString:?beijingDateString];

NSTimeIntervalbeiInterval = [beiDate?? timeIntervalSince1970];

NSDate*LocDate = [localFormatter?? dateFromString:?localTimeString];

NSTimeIntervalLocInterval = [LocDate? timeIntervalSince1970];

NSLog(@"原始时间戳:%@?北京时区生成时间戳:%f??本地时区生成时间戳:%f ",test,( double )beiInterval,( double )?LocInterval);

结果打印: ?原始时间戳:1652861974? 北京时区生成时间戳:1652861974.000000 ? 本地时区生成时间戳:1652861974.000000?

验证了同一时刻虽然处于世界不同时区,但是拿到的时间戳是一样的,前提是转成对应时区下的日期即 NSDateFormatter要设置对应的时区。

(责任编辑:IT教学网)

更多

相关综合特效文章

推荐综合特效文章