HebrewCalendar.AddYears(DateTime, Int32) メソッド

定義

指定した DateTime から指定した年数が経過した後の DateTime を返します。

public override DateTime AddYears (DateTime time, int years);

パラメーター

time
DateTime

years を加算する対象の DateTime

years
Int32

加算する年数。

戻り値

指定した DateTime に指定した年数を加算した結果の DateTime

例外

結果として得られる DateTime がサポートされている範囲外の値です。

次のコード例では、 の複数のコンポーネントの値を DateTime ヘブライ暦の観点から表示します。

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

*/

注釈

このクラスの HebrewCalendar 実装では、ヘブライ語の年 5343 年から 5999 年 (グレゴリオ暦では 1583 年から 2239 年) のみが認識されます。

結果の日が、結果の年の結果 DateTime の月の有効な日でない場合、結果の日の部分が影響を受ける。 結果の年の結果の月の最後の有効な日に変更されます。 たとえば、Cheshvan は、ユダヤ人の祝日の配置に応じて、29 日または 30 日を持つことができます。 Cheshvan が現在の年に 30 日、次の年に 29 日があるとします。 指定した日付が現在の年の Cheshvan の 30 日で、 の years 値が 1 の場合、結果の日付は次の年の Cheshvan の 29 日目になります。

結果の月が結果 DateTime の年の有効な月でない場合、結果の月の部分が影響を受ける。 これは、結果として得られる年の最後の有効な月に変更されます。 たとえば、 パラメーターの time 月が閏年の 13 か月目で、 の years 値が 1 の場合、結果の月 DateTime は次の年の 12 か月目になります。これは閏年ではありません。 月の部分が変更されない場合でも、別の月を参照する可能性があることに注意してください。 たとえば、Adar Beit は閏年で 7 か月目ですが、日産は共通年で 7 か月目です。

この実装では、現在の時代 (年号) のみがサポートされます。 したがって、 は、 ArgumentException 結果の年が指定された の時代 (年号) の範囲外の場合にスローされます DateTime

結果 DateTime のの時刻部分は、指定した DateTimeと同じままです。

が負の場合 years 、結果 DateTime は指定された DateTimeよりも前になります。

戻りDateTime値の プロパティはKind常に とDateTimeKind.Unspecified等しくなります。 次の例に Kind 示すように、 メソッドを time 呼び出 DateTime.SpecifyKind すことで、 パラメーターの プロパティを保持できます。

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

適用対象

製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

こちらもご覧ください