This article mainly introduces the detailed explanation of the Java Calendar class and relevant information on usage examples. Friends in need can refer to the following
Summary of the use of the Java Calendar class
In actual projects, we often involve time processing. For example, when logging into a website, we will see XXX displayed on the homepage of the website. Welcome! Today is the year XXXX. . . . Some websites will record the time when users log in, such as some websites of banks. For these problems that often need to be dealt with, Java provides Calendar, a class specially used to operate on dates. So what is special about this class? , First let’s look at Calendar’s declaration
public abstract class Calendar extends Objectimplements Serializable, Cloneable, Comparable<Calendar>
This class is modified by abstract, indicating that the instance cannot be obtained through new. In this regard, Calendar provides a class method getInstance to obtain a general object of this type. Object, the getInstance method returns a Calendar object (this object is a subclass object of Calendar), and its calendar field has been initialized by the current date and time:
Calendar rightNow = Calendar.getInstance();
Why is it said that a subclass object of Calendar is returned? Because each country and region has its own set of calendar algorithms. For example, the first week in Western countries is mostly Sunday, while in China it is Monday. Let’s take a look at the source code of the getInstance method to obtain the instance
/** * Gets a calendar using the default time zone and locale. The * <code>Calendar</code> returned is based on the current time * in the default time zone with the default locale. * * @return a Calendar. */ public static Calendar getInstance() { Calendar cal = createCalendar(TimeZone.getDefaultRef(), Locale.getDefault(Locale.Category.FORMAT)); cal.sharedZone = true; return cal; }
The createCalendar method is to return the corresponding date subclasses according to different countries and regions
private static Calendar createCalendar(TimeZone zone, Locale aLocale) { Calendar cal = null; String caltype = aLocale.getUnicodeLocaleType("ca"); if (caltype == null) { // Calendar type is not specified. // If the specified locale is a Thai locale, // returns a BuddhistCalendar instance. if ("th".equals(aLocale.getLanguage()) && ("TH".equals(aLocale.getCountry()))) { cal = new BuddhistCalendar(zone, aLocale); } else { cal = new GregorianCalendar(zone, aLocale); } } else if (caltype.equals("japanese")) { cal = new JapaneseImperialCalendar(zone, aLocale); } else if (caltype.equals("buddhist")) { cal = new BuddhistCalendar(zone, aLocale); } else { // Unsupported calendar type. // Use Gregorian calendar as a fallback. cal = new GregorianCalendar(zone, aLocale); } return cal; }
In order to operate dates more conveniently, the Calendar class provides conversion between calendar fields such as YEAR, MONTH, DAY_OF_MONTH, HOUR and so on. methods and provides some methods for manipulating calendar fields (such as getting next week's date). An instant can be expressed as a millisecond value, which is the offset from the epoch (00:00:00.000 January 1, 1970 GMT, Gregorian calendar).
Let’s take a look at the commonly used methods of Calendar
package com.test.calendar; import java.util.Calendar; import org.junit.Before; import org.junit.Test; public class CalendarDemo { Calendar calendar = null; @Before public void test() { calendar = Calendar.getInstance(); } // 基本用法,获取年月日时分秒星期 @Test public void test1() { // 获取年 int year = calendar.get(Calendar.YEAR); // 获取月,这里需要需要月份的范围为0~11,因此获取月份的时候需要+1才是当前月份值 int month = calendar.get(Calendar.MONTH) + 1; // 获取日 int day = calendar.get(Calendar.DAY_OF_MONTH); // 获取时 int hour = calendar.get(Calendar.HOUR); // int hour = calendar.get(Calendar.HOUR_OF_DAY); // 24小时表示 // 获取分 int minute = calendar.get(Calendar.MINUTE); // 获取秒 int second = calendar.get(Calendar.SECOND); // 星期,英语国家星期从星期日开始计算 int weekday = calendar.get(Calendar.DAY_OF_WEEK); System.out.println("现在是" + year + "年" + month + "月" + day + "日" + hour + "时" + minute + "分" + second + "秒" + "星期" + weekday); } // 一年后的今天 @Test public void test2() { // 同理换成下个月的今天calendar.add(Calendar.MONTH, 1); calendar.add(Calendar.YEAR, 1); // 获取年 int year = calendar.get(Calendar.YEAR); // 获取月 int month = calendar.get(Calendar.MONTH) + 1; // 获取日 int day = calendar.get(Calendar.DAY_OF_MONTH); System.out.println("一年后的今天:" + year + "年" + month + "月" + day + "日"); } // 获取任意一个月的最后一天 @Test public void test3() { // 假设求6月的最后一天 int currentMonth = 6; // 先求出7月份的第一天,实际中这里6为外部传递进来的currentMonth变量 // 1 calendar.set(calendar.get(Calendar.YEAR), currentMonth, 1); calendar.add(Calendar.DATE, -1); // 获取日 int day = calendar.get(Calendar.DAY_OF_MONTH); System.out.println("6月份的最后一天为" + day + "号"); } // 设置日期 @Test public void test4() { calendar.set(Calendar.YEAR, 2000); System.out.println("现在是" + calendar.get(Calendar.YEAR) + "年"); calendar.set(2008, 8, 8); // 获取年 int year = calendar.get(Calendar.YEAR); // 获取月 int month = calendar.get(Calendar.MONTH); // 获取日 int day = calendar.get(Calendar.DAY_OF_MONTH); System.out.println("现在是" + year + "年" + month + "月" + day + "日"); } }
Program output results:
现在是2016年11月7日11时42分18秒星期2 一年后的今天:2017年11月7日 6月份的最后一天为30号 现在是2000年 现在是2008年8月8日
The Calendar class also has before, after, compareTo and other methods. The usage is similar to that of the Date class. It’s just now recommended to use the Calendar class to operate dates.
The above is the detailed content of Introduction and usage tutorial of Java Calendar class. For more information, please follow other related articles on the PHP Chinese website!

JVM implements the WORA features of Java through bytecode interpretation, platform-independent APIs and dynamic class loading: 1. Bytecode is interpreted as machine code to ensure cross-platform operation; 2. Standard API abstract operating system differences; 3. Classes are loaded dynamically at runtime to ensure consistency.

The latest version of Java effectively solves platform-specific problems through JVM optimization, standard library improvements and third-party library support. 1) JVM optimization, such as Java11's ZGC improves garbage collection performance. 2) Standard library improvements, such as Java9's module system reducing platform-related problems. 3) Third-party libraries provide platform-optimized versions, such as OpenCV.

The JVM's bytecode verification process includes four key steps: 1) Check whether the class file format complies with the specifications, 2) Verify the validity and correctness of the bytecode instructions, 3) Perform data flow analysis to ensure type safety, and 4) Balancing the thoroughness and performance of verification. Through these steps, the JVM ensures that only secure, correct bytecode is executed, thereby protecting the integrity and security of the program.

Java'splatformindependenceallowsapplicationstorunonanyoperatingsystemwithaJVM.1)Singlecodebase:writeandcompileonceforallplatforms.2)Easyupdates:updatebytecodeforsimultaneousdeployment.3)Testingefficiency:testononeplatformforuniversalbehavior.4)Scalab

Java's platform independence is continuously enhanced through technologies such as JVM, JIT compilation, standardization, generics, lambda expressions and ProjectPanama. Since the 1990s, Java has evolved from basic JVM to high-performance modern JVM, ensuring consistency and efficiency of code across different platforms.

How does Java alleviate platform-specific problems? Java implements platform-independent through JVM and standard libraries. 1) Use bytecode and JVM to abstract the operating system differences; 2) The standard library provides cross-platform APIs, such as Paths class processing file paths, and Charset class processing character encoding; 3) Use configuration files and multi-platform testing in actual projects for optimization and debugging.

Java'splatformindependenceenhancesmicroservicesarchitecturebyofferingdeploymentflexibility,consistency,scalability,andportability.1)DeploymentflexibilityallowsmicroservicestorunonanyplatformwithaJVM.2)Consistencyacrossservicessimplifiesdevelopmentand

GraalVM enhances Java's platform independence in three ways: 1. Cross-language interoperability, allowing Java to seamlessly interoperate with other languages; 2. Independent runtime environment, compile Java programs into local executable files through GraalVMNativeImage; 3. Performance optimization, Graal compiler generates efficient machine code to improve the performance and consistency of Java programs.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

SublimeText3 Chinese version
Chinese version, very easy to use

Dreamweaver CS6
Visual web development tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

WebStorm Mac version
Useful JavaScript development tools
