HebrewCalendar.AddYears(DateTime, Int32) Metodo

Definizione

Restituisce un valore DateTime che rappresenta il numero di anni specificato a partire dal valore DateTime specificato.Returns a DateTime that is the specified number of years away from the specified DateTime.

public:
 override DateTime AddYears(DateTime time, int years);
public override DateTime AddYears (DateTime time, int years);
override this.AddYears : DateTime * int -> DateTime
Public Overrides Function AddYears (time As DateTime, years As Integer) As DateTime

Parametri

time
DateTime

Valore DateTime al quale aggiungere years.The DateTime to which to add years.

years
Int32

Numero di anni da aggiungere.The number of years to add.

Restituisce

Valore DateTime risultante dalla somma del numero di anni specificato e del valore DateTime specificato.The DateTime that results from adding the specified number of years to the specified DateTime.

Eccezioni

Il valore DateTime risultante non è compreso nell’intervallo supportato.The resulting DateTime is outside the supported range.

Esempio

Nell'esempio di codice seguente vengono visualizzati i valori di diversi componenti di un DateTime in termini di calendario ebraico.The following code example displays the values of several components of a DateTime in terms of the Hebrew calendar.

using namespace System;
using namespace System::Globalization;
void DisplayValues( Calendar^ myCal, DateTime myDT )
{
   Console::WriteLine( "   Era:        {0}", myCal->GetEra( myDT ) );
   Console::WriteLine( "   Year:       {0}", myCal->GetYear( myDT ) );
   Console::WriteLine( "   Month:      {0}", myCal->GetMonth( myDT ) );
   Console::WriteLine( "   DayOfYear:  {0}", myCal->GetDayOfYear( myDT ) );
   Console::WriteLine( "   DayOfMonth: {0}", myCal->GetDayOfMonth( myDT ) );
   Console::WriteLine( "   DayOfWeek:  {0}", myCal->GetDayOfWeek( myDT ) );
   Console::WriteLine();
}

int main()
{
   
   // Sets a DateTime to April 3, 2002 of the Gregorian calendar.
   DateTime myDT = DateTime(2002,4,3,gcnew GregorianCalendar);
   
   // Creates an instance of the HebrewCalendar.
   HebrewCalendar^ myCal = gcnew HebrewCalendar;
   
   // Displays the values of the DateTime.
   Console::WriteLine( "April 3, 2002 of the Gregorian calendar equals the following in the Hebrew calendar:" );
   DisplayValues( myCal, myDT );
   
   // Adds two years and ten months.
   myDT = myCal->AddYears( myDT, 2 );
   myDT = myCal->AddMonths( myDT, 10 );
   
   // Displays the values of the DateTime.
   Console::WriteLine( "After adding two years and ten months:" );
   DisplayValues( myCal, myDT );
}

/*
This code produces the following output.

April 3, 2002 of the Gregorian calendar equals the following in the Hebrew calendar:
   Era:        1
   Year:       5762
   Month:      7
   DayOfYear:  198
   DayOfMonth: 21
   DayOfWeek:  Wednesday

After adding two years and ten months:
   Era:        1
   Year:       5765
   Month:      5
   DayOfYear:  138
   DayOfMonth: 21
   DayOfWeek:  Monday

*/
using System;
using System.Globalization;

public class SamplesHebrewCalendar  {

   public static void Main()  {

      // Sets a DateTime to April 3, 2002 of the Gregorian calendar.
      DateTime myDT = new DateTime( 2002, 4, 3, new GregorianCalendar() );

      // Creates an instance of the HebrewCalendar.
      HebrewCalendar myCal = new HebrewCalendar();

      // Displays the values of the DateTime.
      Console.WriteLine( "April 3, 2002 of the Gregorian calendar equals the following in the Hebrew calendar:" );
      DisplayValues( myCal, myDT );

      // Adds two years and ten months.
      myDT = myCal.AddYears( myDT, 2 );
      myDT = myCal.AddMonths( myDT, 10 );

      // Displays the values of the DateTime.
      Console.WriteLine( "After adding two years and ten months:" );
      DisplayValues( myCal, myDT );
   }

   public static void DisplayValues( Calendar myCal, DateTime myDT )  {
      Console.WriteLine( "   Era:        {0}", myCal.GetEra( myDT ) );
      Console.WriteLine( "   Year:       {0}", myCal.GetYear( myDT ) );
      Console.WriteLine( "   Month:      {0}", myCal.GetMonth( myDT ) );
      Console.WriteLine( "   DayOfYear:  {0}", myCal.GetDayOfYear( myDT ) );
      Console.WriteLine( "   DayOfMonth: {0}", myCal.GetDayOfMonth( myDT ) );
      Console.WriteLine( "   DayOfWeek:  {0}", myCal.GetDayOfWeek( myDT ) );
      Console.WriteLine();
   }
}

/*
This code produces the following output.

April 3, 2002 of the Gregorian calendar equals the following in the Hebrew calendar:
   Era:        1
   Year:       5762
   Month:      7
   DayOfYear:  198
   DayOfMonth: 21
   DayOfWeek:  Wednesday

After adding two years and ten months:
   Era:        1
   Year:       5765
   Month:      5
   DayOfYear:  138
   DayOfMonth: 21
   DayOfWeek:  Monday

*/
Imports System.Globalization


Public Class SamplesHebrewCalendar   

   Public Shared Sub Main()

      ' 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 HebrewCalendar.
      Dim myCal As New HebrewCalendar()

      ' Displays the values of the DateTime.
      Console.WriteLine("April 3, 2002 of the Gregorian calendar equals the following in the Hebrew calendar:")
      DisplayValues(myCal, myDT)

      ' Adds two years and ten months.
      myDT = myCal.AddYears(myDT, 2)
      myDT = myCal.AddMonths(myDT, 10)

      ' Displays the values of the DateTime.
      Console.WriteLine("After adding two years and ten months:")
      DisplayValues(myCal, myDT)

   End Sub

   Public Shared Sub DisplayValues(myCal As Calendar, myDT As DateTime)
      Console.WriteLine("   Era:        {0}", myCal.GetEra(myDT))
      Console.WriteLine("   Year:       {0}", myCal.GetYear(myDT))
      Console.WriteLine("   Month:      {0}", myCal.GetMonth(myDT))
      Console.WriteLine("   DayOfYear:  {0}", myCal.GetDayOfYear(myDT))
      Console.WriteLine("   DayOfMonth: {0}", myCal.GetDayOfMonth(myDT))
      Console.WriteLine("   DayOfWeek:  {0}", myCal.GetDayOfWeek(myDT))
      Console.WriteLine()
   End Sub

End Class



'This code produces the following output.

'

'April 3, 2002 of the Gregorian calendar equals the following in the Hebrew calendar:

'   Era:        1

'   Year:       5762

'   Month:      7

'   DayOfYear:  198

'   DayOfMonth: 21

'   DayOfWeek:  Wednesday

'

'After adding two years and ten months:

'   Era:        1

'   Year:       5765

'   Month:      5

'   DayOfYear:  138

'   DayOfMonth: 21

'   DayOfWeek:  Monday


Commenti

Questa implementazione della classe HebrewCalendar riconosce solo gli anni ebraici da 5343 a 5999 (da 1583 a 2239 nel calendario gregoriano).This implementation of the HebrewCalendar class recognizes only the Hebrew years 5343 to 5999 (1583 to 2239 in the Gregorian calendar).

La parte relativa al giorno dell'DateTime risultante viene interessata se il giorno risultante non è un giorno valido nel mese risultante dell'anno risultante.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. Viene modificato nell'ultimo giorno valido del mese risultante dell'anno risultante.It is changed to the last valid day in the resulting month of the resulting year. Ad esempio, Cheshvan può avere 29 o 30 giorni, a seconda del posizionamento delle festività ebraiche.For example, Cheshvan can have 29 or 30 days, depending on the placement of Jewish holidays. Si supponga che Cheshvan abbia 30 giorni nell'anno corrente e 29 nell'anno successivo.Suppose that Cheshvan has 30 days in the current year and 29 in the following year. Se la data specificata è il 30 ° giorno di Cheshvan nell'anno corrente e il valore di years è 1, la data risultante sarà il ventinovesimo giorno di Cheshvan nell'anno successivo.If the specified date is the 30th day of Cheshvan in the current year and the value of years is 1, the resulting date will be the 29th day of Cheshvan in the following year.

La parte relativa al mese del DateTime risultante viene interessata se il mese risultante non è un mese valido nell'anno risultante.The month part of the resulting DateTime is affected if the resulting month is not a valid month in the resulting year. Viene modificato nell'ultimo mese valido nell'anno risultante.It is changed to the last valid month in the resulting year. Se, ad esempio, il mese nel parametro time è il tredicesimo mese di un anno bisestile e il valore di years è 1, il mese nel DateTime risultante è il dodicesimo mese dell'anno successivo, ovvero un anno non bisestile.For example, if the month in the time parameter is the 13th month of a leap year and the value of years is 1, the month in the resulting DateTime is the 12th month of the following year, which is a non-leap year. Si noti che anche quando la parte relativa al mese non cambia, può comunque riferirsi a un mese diverso.Note that even when the month part does not change, it might still refer to a different month. Ad esempio, Adar Beit è il settimo mese negli anni bisestili, ma Nissan è il settimo mese in anni comuni.For example, Adar Beit is the 7th month in leap years, but Nissan is the 7th month in common years.

Questa implementazione supporta solo l'era corrente.This implementation supports only the current era. Pertanto, ArgumentException viene generata se l'anno risultante non rientra nell'era del DateTimespecificato.Therefore, ArgumentException is thrown if the resulting year is outside the era of the specified DateTime.

La parte relativa all'ora del DateTime risultante rimane identica alla DateTimespecificata.The time-of-day part of the resulting DateTime remains the same as the specified DateTime.

Se years è negativo, il DateTime risultante è precedente al DateTimespecificato.If years is negative, the resulting DateTime is earlier than the specified DateTime.

La proprietà Kind del valore DateTime restituito è sempre uguale a DateTimeKind.Unspecified.The Kind property of the returned DateTime value always equals DateTimeKind.Unspecified. È possibile mantenere la proprietà Kind del parametro time chiamando il metodo DateTime.SpecifyKind, come illustrato nell'esempio riportato di seguito.You can preserve the Kind property of the time parameter by calling the DateTime.SpecifyKind method, as the following example shows.

returnTime = DateTime.SpecifyKind(cal.AddYears(time, years), time.Kind);
returnTime = DateTime.SpecifyKind(cal.AddYears(time, years), time.Kind)

Si applica a

Vedi anche