KoreanCalendar.AddYears Method
[ This article is for Windows Phone 8 developers. If you’re developing for Windows 10, see the latest documentation. ]
Returns a DateTime that is the specified number of years away from the specified DateTime.
Assembly: mscorlib (in mscorlib.dll)
'Declaration Public Overrides Function AddYears ( _ time As DateTime, _ years As Integer _ ) As DateTime
Parameters
- time
- Type: System.DateTime
The DateTime to which to add years.
- years
- Type: System.Int32
The number of years to add.
Return Value
Type: System.DateTimeThe DateTime that results from adding the specified number of years to the specified DateTime.
| Exception | Condition |
|---|---|
| ArgumentOutOfRangeException | years or time is out of range. |
The day part of the resulting DateTime is affected if the resulting day is not a valid day in the resulting month of the resulting year. It is changed to the last valid day in the resulting month of the resulting year. The month part of the resulting DateTime remains the same as the specified DateTime. This implementation supports only the current era. Therefore, ArgumentException is thrown if the resulting year is outside the era of the specified DateTime. The time-of-day part of the resulting DateTime remains the same as the specified DateTime.
For example, February has 28 days, except during leap years when it has 29 days. If the specified date is the 29th day of February in a leap year and the value of years is 1, the resulting date is the 28th day of February in the following year.
If years is negative, the resulting DateTime is earlier than the specified DateTime.
The Kind property of the returned DateTime value always equals DateTimeKind.Unspecified. You can preserve the Kind property of the time parameter by calling the DateTime.SpecifyKind method, as the following example shows.
The following code example displays the values of several components of a DateTime in terms of the Korean calendar.
Imports System.Globalization Public Class Example Public Shared Sub Demo(ByVal outputBlock As System.Windows.Controls.TextBlock) ' Sets a DateTime to April 3, 2002 of the Gregorian calendar. Dim myDT As New DateTime(2002, 4, 3, New GregorianCalendar()) ' Creates an instance of the KoreanCalendar. Dim myCal As New KoreanCalendar() ' Displays the values of the DateTime. outputBlock.Text += String.Format("April 3, 2002 of the Gregorian calendar equals the following in the Korean calendar:") & vbCrLf DisplayValues(outputBlock, myCal, myDT) ' Adds two years and ten months. myDT = myCal.AddYears(myDT, 2) myDT = myCal.AddMonths(myDT, 10) ' Displays the values of the DateTime. outputBlock.Text &= "After adding two years and ten months:" & vbCrLf DisplayValues(outputBlock, myCal, myDT) End Sub Public Shared Sub DisplayValues(ByVal outputBlock As System.Windows.Controls.TextBlock, _ ByVal myCal As Calendar, ByVal myDT As DateTime) outputBlock.Text += String.Format(" Era: {0}", myCal.GetEra(myDT)) & vbCrLf outputBlock.Text += String.Format(" Year: {0}", myCal.GetYear(myDT)) & vbCrLf outputBlock.Text += String.Format(" Month: {0}", myCal.GetMonth(myDT)) & vbCrLf outputBlock.Text += String.Format(" DayOfYear: {0}", myCal.GetDayOfYear(myDT)) & vbCrLf outputBlock.Text += String.Format(" DayOfMonth: {0}", myCal.GetDayOfMonth(myDT)) & vbCrLf outputBlock.Text += String.Format(" DayOfWeek: {0}", myCal.GetDayOfWeek(myDT)) & vbCrLf outputBlock.Text &= vbCrLf End Sub End Class ' This example produces the following output. ' April 3, 2002 of the Gregorian calendar equals the following in the Korean calendar: ' Era: 1 ' Year: 4335 ' Month: 4 ' DayOfYear: 93 ' DayOfMonth: 3 ' DayOfWeek: Wednesday ' ' After adding two years and ten months: ' Era: 1 ' Year: 4338 ' Month: 2 ' DayOfYear: 34 ' DayOfMonth: 3 ' DayOfWeek: Thursday