2024年最新死磕18个Java8日期处理,工作必用!,rabbitmq和kafka的区别面试

Java高频面试专题合集解析:

阿里Java岗面试百题:Spring 缓存 JVM 微服务 数据库 RabbitMQ等

当然在这还有更多整理总结的Java进阶学习笔记和面试题未展示,其中囊括了Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并发等架构资料和完整的Java架构学习进阶导图!

阿里Java岗面试百题:Spring 缓存 JVM 微服务 数据库 RabbitMQ等

更多Java架构进阶资料展示

阿里Java岗面试百题:Spring 缓存 JVM 微服务 数据库 RabbitMQ等

阿里Java岗面试百题:Spring 缓存 JVM 微服务 数据库 RabbitMQ等

阿里Java岗面试百题:Spring 缓存 JVM 微服务 数据库 RabbitMQ等

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

}

只要当天的日期和生日匹配,无论是哪一年都会打印出祝贺信息。你可以把程序整合进系统时钟,看看生日时是否会受到提醒,或者写一个单元测试来检测代码是否运行正确。

示例6:Java 8中获取当前时间

package com.shxt.demo02;

import java.time.LocalTime;

public class Demo06 {

public static void main(String[] args) {

LocalTime time = LocalTime.now();

System.out.println(“获取当前的时间,不含有日期:”+time);

}

}

可以看到当前时间就只包含时间信息,没有日期

示例7:Java 8中获取当前时间

通过增加小时、分、秒来计算将来的时间很常见。Java 8除了不变类型和线程安全的好处之外,还提供了更好的plusHours()方法替换add(),并且是兼容的。注意,这些方法返回一个全新的LocalTime实例,由于其不可变性,返回后一定要用变量赋值。

package com.shxt.demo02;

import java.time.LocalTime;

public class Demo07 {

public static void main(String[] args) {

LocalTime time = LocalTime.now();

LocalTime newTime = time.plusHours(3);

System.out.println(“三个小时后的时间为:”+newTime);

}

}

示例8:Java 8如何计算一周后的日期

和上个例子计算3小时以后的时间类似,这个例子会计算一周后的日期。LocalDate日期不包含时间信息,它的plus()方法用来增加天、周、月,ChronoUnit类声明了这些时间单位。由于LocalDate也是不变类型,返回后一定要用变量赋值。

package com.shxt.demo02;

import java.time.LocalDate;

import java.time.temporal.ChronoUnit;

public class Demo08 {

public static void main(String[] args) {

LocalDate today = LocalDate.now();

System.out.println(“今天的日期为:”+today);

LocalDate nextWeek = today.plus(1, ChronoUnit.WEEKS);

System.out.println(“一周后的日期为:”+nextWeek);

}

}

可以看到新日期离当天日期是7天,也就是一周。你可以用同样的方法增加1个月、1年、1小时、1分钟甚至一个世纪,更多选项可以查看Java 8 API中的ChronoUnit类

示例9:Java 8计算一年前或一年后的日期

利用minus()方法计算一年前的日期

package com.shxt.demo02;

import java.time.LocalDate;

import java.time.temporal.ChronoUnit;

public class Demo09 {

public static void main(String[] args) {

LocalDate today = LocalDate.now();

LocalDate previousYear = today.minus(1, ChronoUnit.YEARS);

System.out.println("一年前的日期 : " + previousYear);

LocalDate nextYear = today.plus(1, ChronoUnit.YEARS);

System.out.println(“一年后的日期:”+nextYear);

}

}

示例10:Java 8的Clock时钟类

Java 8增加了一个Clock时钟类用于获取当时的时间戳,或当前时区下的日期时间信息。以前用到System.currentTimeInMillis()和TimeZone.getDefault()的地方都可用Clock替换。

package com.shxt.demo02;

import java.time.Clock;

public class Demo10 {

public static void main(String[] args) {

// Returns the current time based on your system clock and set to UTC.

Clock clock = Clock.systemUTC();

System.out.println("Clock : " + clock.millis());

// Returns time based on system clock zone

Clock defaultClock = Clock.systemDefaultZone();

System.out.println("Clock : " + defaultClock.millis());

}

}

示例11:如何用Java判断日期是早于还是晚于另一个日期

另一个工作中常见的操作就是如何判断给定的一个日期是大于某天还是小于某天?在Java 8中,LocalDate类有两类方法isBefore()和isAfter()用于比较日期。调用isBefore()方法时,如果给定日期小于当前日期则返回true。

package com.shxt.demo02;

import java.time.LocalDate;

import java.time.temporal.ChronoUnit;

public class Demo11 {

public static void main(String[] args) {

LocalDate today = LocalDate.now();

LocalDate tomorrow = LocalDate.of(2018,2,6);

if(tomorrow.isAfter(today)){

System.out.println(“之后的日期:”+tomorrow);

}

LocalDate yesterday = today.minus(1, ChronoUnit.DAYS);

if(yesterday.isBefore(today)){

System.out.println(“之前的日期:”+yesterday);

}

}

}

示例12:Java 8中处理时区

Java 8不仅分离了日期和时间,也把时区分离出来了。现在有一系列单独的类如ZoneId来处理特定时区,ZoneDateTime类来表示某时区下的时间。这在Java 8以前都是 GregorianCalendar类来做的。下面这个例子展示了如何把本时区的时间转换成另一个时区的时间。

package com.shxt.demo02;

import java.time.LocalDateTime;

import java.time.ZoneId;

import java.time.ZonedDateTime;

public class Demo12 {

public static void main(String[] args) {

// Date and time with timezone in Java 8

ZoneId america = ZoneId.of(“America/New_York”);

LocalDateTime localtDateAndTime = LocalDateTime.now();

ZonedDateTime dateAndTimeInNewYork  = ZonedDateTime.of(localtDateAndTime, america );

System.out.println("Current date and time in a particular timezone : " + dateAndTimeInNewYork);

}

}

示例13:如何表示信用卡到期这类固定日期,答案就在YearMonth

与 MonthDay检查重复事件的例子相似,YearMonth是另一个组合类,用于表示信用卡到期日、FD到期日、期货期权到期日等。还可以用这个类得到 当月共有多少天,YearMonth实例的lengthOfMonth()方法可以返回当月的天数,在判断2月有28天还是29天时非常有用。

package com.shxt.demo02;

import java.time.*;

public class Demo13 {

public static void main(String[] args) {

YearMonth currentYearMonth = YearMonth.now();

System.out.printf(“Days in month year %s: %d%n”, currentYearMonth, currentYearMonth.lengthOfMonth());

YearMonth creditCardExpiry = YearMonth.of(2019, Month.FEBRUARY);

System.out.printf(“Your credit card expires on %s %n”, creditCardExpiry);

}

}

示例14:如何在Java 8中检查闰年

package com.shxt.demo02;

import java.time.LocalDate;

public class Demo14 {

public static void main(String[] args) {

LocalDate today = LocalDate.now();

if(today.isLeapYear()){

System.out.println(“This year is Leap year”);

}else {

System.out.println(“2018 is not a Leap year”);

}

}

}

示例15:计算两个日期之间的天数和月数

有一个常见日期操作是计算两个日期之间的天数、周数或月数。在Java 8中可以用java.time.Period类来做计算。

下面这个例子中,我们计算了当天和将来某一天之间的月数。

package com.shxt.demo02;

import java.time.LocalDate;

import java.time.Period;

public class Demo15 {

public static void main(String[] args) {

LocalDate today = LocalDate.now();

LocalDate java8Release = LocalDate.of(2018, 12, 14);

Period periodToNextJavaRelease = Period.between(today, java8Release);

System.out.println("Months left between today and Java 8 release : "

+ periodToNextJavaRelease.getMonths() );

}

}

示例16:在Java 8中获取当前的时间戳

Instant类有一个静态工厂方法now()会返回当前的时间戳,如下所示:

package com.shxt.demo02;

import java.time.Instant;

public class Demo16 {

public static void main(String[] args) {

Instant timestamp = Instant.now();

System.out.println("What is value of this instant " + timestamp.toEpochMilli());

}

}

时间戳信息里同时包含了日期和时间,这和java.util.Date很像。实际上Instant类确实等同于 Java 8之前的Date类,你可以使用Date类和Instant类各自的转换方法互相转换,例如:Date.from(Instant) 将Instant转换成java.util.Date,Date.toInstant()则是将Date类转换成Instant类。

示例17:Java 8中如何使用预定义的格式化工具去解析或格式化日期

package com.shxt.demo02;

import java.time.LocalDate;

import java.time.format.DateTimeFormatter;

最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

image

上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)

image

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

package com.shxt.demo02;

import java.time.LocalDate;

import java.time.format.DateTimeFormatter;

最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

[外链图片转存中…(img-VCBL03XG-1715250562991)]

上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)

[外链图片转存中…(img-kHICdidJ-1715250562992)]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: RabbitMQKafka 有以下主要区别: 1. 架构:RabbitMQ 是一个消息代理,而 Kafka 是一个分布式流平台。 2. 实现:RabbitMQ 基于队列模型,Kafka 基于发布/订阅模型。 3. 吞吐量:Kafka 的吞吐量更高,因为它具有分布式架构。 4. 持久性:Kafka 消息存储更长,因为它使用分布式文件系统。 5. 可靠性:RabbitMQ 提供更高的可靠性,因为它支持事务和可靠性投递。 6. 用途:RabbitMQ 适用于异步通信和任务队列,Kafka 适用于大规模数据处理和实时流数据。 ### 回答2: RabbitMQKafka是目前流行的消息中间件,常常被用于分布式系统中的异步通信。下面我将从以下几方面来回答这道面试题目:消息模型、消息顺序、消息传输、消息可靠性、性能以及社区支持。 1. 消息模型 RabbitMQ采用标准的AMQP协议,支持消息的持久化,消息可靠性较高,可以设置队列的过期时间、消息优先级和消息路由规则等。RabbitMQ的代码实现和架构较为简单,适合实现任务队列、分发、RPC等场景。 而Kafka采用发布-订阅模式,支持消息的批量处理和异步处理,能够高效地处理大量数据流,适用于高吞吐量的场景,如日志收集、实时计算等。 2. 消息顺序 RabbitMQ采用FIFO(先进先出)模式,保证消息的顺序。但是在分布式环境下,当消息被多个消费者同时消费时,队列的顺序可能会被打乱。 而Kafka采用分区机制,支持多个订阅者对同一分区进行消费,并保证消息顺序,因此在分布式环境下,Kafka消息的顺序更可靠。 3. 消息传输 RabbitMQ消息传输采用AMQP协议,需要建立TCP连接,较为重量级。而Kafka采用Zero-copy技术,消息传输速度更快。 4. 消息可靠性 RabbitMQ可以通过消息持久化、消息确认等机制来保证消息的可靠性,但在高并发场景下容易出现消息堆积、阻塞的情况。 Kafka采用副本机制,将每个分区的数据副本分布到多个Broker上,避免了单点故障,保证了高可靠性。 5. 性能 Kafka的性能优于RabbitMQ,尤其是在海量数据处理场景下,Kafka的吞吐量甚至可以达到百万级别。 6. 社区支持 RabbitMQ社区较为活跃,拥有大量的插件和扩展,同时也有较为完善的文档和支持。而Kafka的社区也很活跃,特别是在大数据领域得到了广泛应用。 综上所述,RabbitMQKafka都是优秀的消息中间件,具体使用还需根据业务场景和需求来决定。对于需要高吞吐量和海量数据处理的场景,可以选择Kafka。对于需要保证消息可靠性和队列顺序的场景,可以选择RabbitMQ。总之,在选择中间件时需要考虑到多个方面的因素,并综合评估各种可能的解决方案。 ### 回答3: RabbitMQKafka都是流行的消息队列系统,用于支持分布式应用程序之间的异步通信。它们都能够高效地处理海量的数据流和消息传递,从而在不同的应用场景之间提供了更好的可伸缩性和可靠性。然而,它们之间也有一些明显的区别,这些区别需要根据具体的业务需求来进行选择。 第一,RabbitMQ是基于AMQP协议的,而Kafka是基于发布-订阅模型的消息传递系统。因此,RabbitMQ更适合于复杂的消息传递场景,例如要求消息队列能够支持事务等高级特性的场景,同时它提供了集群化的高可用性,支持消息的持久化和可靠性传递;而Kafka更适合于实时数据流处理的场景,例如日志收集、实时分析和数据管理,因为它的架构采用了多副本备份的方式来保证数据的可靠性,并提供了更高的吞吐量和较低的延迟。 第二,RabbitMQ为了防止消息阻塞,采用了预取机制,也就是在向自己注册消费者时,可以通过设置prefetch参数来控制每次消费的消息数目;而Kafka没有这种预取机制,因为它把消息传递设计为一种持续的流,因此能够更好地处理实时数据流。 第三,RabbitMQ消费者在没有消息时会处于空闲状态,不会占用系统资源;而Kafka消费者在没有消息时会花费更多的CPU和内存资源,因为它在内部轮询消息,而不是确定性地等待消息的到来。此时如果没有消息,就会不断地轮询,浪费系统资源。 第四,RabbitMQ支持消息的推送和拉取两种模式,而Kafka只支持拉取模式。如果应用程序需要及时地获取外部数据,那么可以考虑使用RabbitMQ的推送模式,但如果需要大量处理海量数据,可以选择Kafka的拉取模式,因为它可以在不受限制地一次性获取大量数据。 综上所述,RabbitMQKafka都有各自的优点和应用场景,选择合适的消息队列系统需要根据具体的业务需求来进行调整选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值