FormatException クラス

定義

引数の形式が無効である場合、または複合書式指定文字列が整形式でない場合にスローされる例外。The exception that is thrown when the format of an argument is invalid, or when a composite format string is not well formed.

public ref class FormatException : SystemException
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public class FormatException : SystemException
type FormatException = class
    inherit SystemException
Public Class FormatException
Inherits SystemException
継承
FormatException
派生
属性

注釈

FormatException例外は、次のいずれかの理由でスローされる可能性があります。A FormatException exception can be thrown for one of the following reasons:

  • 文字列を他のデータ型に変換するメソッドの呼び出しでは、文字列が必要なパターンに準拠していません。In a call to a method that converts a string to some other data type, the string doesn't conform to the required pattern. これは通常、 ConvertクラスParseの一部のメソッド、および一部のParseExact型のメソッドとメソッドを呼び出すときに発生します。This typically occurs when calling some methods of the Convert class and the Parse and ParseExact methods of some types.

    特に、変換する文字列がユーザーによって入力されたり、ファイルから読み取られたりする場合は、通常、 try/catchブロックを使用しFormatExceptionて、変換に失敗した場合に例外を処理する必要があります。In most cases, particularly if the string that you're converting is input by a user or read from a file, you should use a try/catch block and handle the FormatException exception if the conversion is unsuccessful. また、変換メソッドの呼び出しを、メソッドまたはTryParse TryParseExactメソッドの呼び出しに置き換えることもできます (存在する場合)。You can also replace the call to the conversion method with a call to a TryParse or TryParseExact method, if one exists. ただし、 FormatException定義済みまたはハードコードされた文字列を解析しようとしたときにスローされる例外は、プログラムエラーを示します。However, a FormatException exception that is thrown when you're trying to parse a predefined or hard-coded string indicates a program error. この場合は、例外を処理するのではなく、エラーを修正する必要があります。In this case, you should correct the error rather than handle the exception.

    System名前空間内の次の型に文字列を変換すると、 FormatException例外がスローされる可能性があります。The conversion of a string to the following types in the System namespace can throw a FormatException exception:

    • BooleanBoolean. メソッドBoolean.Parse(String)Convert.ToBoolean(String)メソッドでは、文字列を "true"、"true"、"false"、または "false" に変換する必要があります。The Boolean.Parse(String) and Convert.ToBoolean(String) methods require the string to be converted to be "True", "true", "False", or "false". それ以外の値はFormatException例外をスローします。Any other value throws a FormatException exception.

    • DateTime および DateTimeOffsetDateTime and DateTimeOffset. すべての日付と時刻のデータは、特定のカルチャの書式指定規則 (現在のスレッドカルチャ (場合によっては、現在のアプリケーションドメインカルチャ)、インバリアントカルチャ、または指定されたカルチャ) に基づいて解釈されます。All date and time data is interpreted based on the formatting conventions of a particular culture: either the current thread culture (or, in some cases, the current application domain culture), the invariant culture, or a specified culture. メソッドDateTime.ParseExact(String, String, IFormatProvider, DateTimeStyles)と** メソッドを呼び出す場合、日付と時刻のデータも、1つ以上の標準書式指定文字列で指定されたパターン、またはの引数として指定されたカスタム書式指定文字列に正確に準拠している必要があります。 DateTimeOffset.ParseExact(String, String[], IFormatProvider, DateTimeStyles)メソッドの呼び出し。When you call the DateTime.ParseExact(String, String, IFormatProvider, DateTimeStyles) and DateTimeOffset.ParseExact(String, String[], IFormatProvider, DateTimeStyles) methods, date and time data must also conform exactly to a pattern specified by one or more standard format strings or custom format strings that are provided as arguments in the method call. 想定されるカルチャ固有のパターンに準拠していないFormatException場合は、例外がスローされます。If it doesn't conform to an expected culture-specific pattern, a FormatException exception is thrown. これは、あるシステムでカルチャ固有の形式で保存された日付と時刻のデータが、別のシステムでは正常に解析されない可能性があることを意味します。This means that date and time data saved in a culture-specific format on one system might not parse successfully on another system.

      日付と時刻の解析の詳細については、「日付と時刻の文字列の解析」と、例外をスローしたメソッドのドキュメントを参照してください。For more information about parsing dates and times, see Parsing Date and Time Strings and the documentation for the method that threw the exception.

    • Guid.GUIDs. GUID の文字列表現は、32の16進数字 (0 ~ F) で構成され、 Guid.ToStringメソッドによって出力される5つの形式のいずれかである必要があります。The string representation of a GUID must consist of 32 hexadecimal digits (0-F), and must be in one of the five formats output by the Guid.ToString method. 詳細については、Guid.Parse メソッドを参照してください。For more information, see the Guid.Parse method.

    • 数値型。すべての符号付き整数、符号なし整数、および浮動小数点型が含まれます。Numeric types, including all signed integers, unsigned integers, and floating-point types. 解析する文字列は、ラテン数字0-9 で構成されている必要があります。The string to be parsed must consist of the Latin digits 0-9. 正または負の符号、桁区切り記号、桁区切り記号、および通貨記号を使用することもできます。A positive or negative sign, decimal separator, group separators, and currency symbol may also be permitted. 他の文字を含む文字列を解析しようとすると、 FormatException常に例外がスローされます。Trying to parse a string that contains any other character always throws a FormatException exception.

      すべての数値文字列は、現在のスレッドカルチャ (場合によっては、現在のアプリケーションドメインカルチャ)、インバリアントカルチャ、または指定されたカルチャの書式指定規則に基づいて解釈されます。All numeric strings are interpreted based on the formatting conventions of a particular culture: either the current thread culture (or, in some cases, the current application domain culture), the invariant culture, or a specified culture. その結果、あるカルチャの規則を使用して解析された数値文字列は、別のカルチャの規則を使用すると失敗する可能性があります。As a result, a numeric string that is parsed by using the conventions of one culture might fail when using the conventions of another.

      数値文字列の解析の詳細については、「数値文字列の解析」と、例外をスローした特定のメソッドのドキュメントを参照してください。For more information about parsing numeric strings, see Parsing Numeric Strings and the documentation for the specific method that threw the exception.

    • 時間間隔。Time intervals. 解析する文字列は、カルチャに依存しない固定形式、または現在のスレッドカルチャ (場合によっては、現在のアプリケーションドメインカルチャ)、インバリアントカルチャ、または指定されたカルチャによって定義されるカルチャに依存する形式である必要があります。The string to be parsed must be either in fixed culture-insensitive format or in a culture-sensitive format defined by the current thread culture (or, in some cases, the current application domain culture), the invariant culture, or a specified culture. 文字列が適切な形式ではない場合、または、時間間隔の日、時間、および分の部分が存在しない場合、解析メソッドは例外をFormatExceptionスローします。If the string isn't in an appropriate format, or if, at the minimum, the days, hours, and minutes components of the time interval aren't present, the parsing method throws a FormatException exception. 詳細については、例外をスロー TimeSpanした解析メソッドのドキュメントを参照してください。For more information, see the documentation for the TimeSpan parsing method that threw the exception.

  • 型はIFormattableインターフェイスを実装します。これは、オブジェクトを文字列形式に変換する方法を定義する書式指定文字列をサポートし、無効な書式指定文字列が使用されます。A type implements the IFormattable interface, which supports format strings that define how an object is converted to its string representation, and an invalid format string is used. これは、書式設定操作で最も一般的です。This is most common in a formatting operation. 次の例では、数値を書式設定するために、複合書式指定文字列で "Q" 標準書式指定文字列が使用されています。In the following example, the "Q" standard format string is used in a composite format string to format a number. ただし、"Q" は有効な標準書式指定文字列ではありません。However, "Q" is not a valid standard format string.

    using System;
    
    public class Example
    {
       public static void Main()
       {
          decimal price = 169.32m;
          Console.WriteLine("The cost is {0:Q2}.", price);
       }
    }
    // The example displays the following output:
    //    Unhandled Exception: System.FormatException: Format specifier was invalid.
    //       at System.Number.FormatDecimal(Decimal value, String format, NumberFormatInfo info)
    //       at System.Decimal.ToString(String format, IFormatProvider provider)
    //       at System.Text.StringBuilder.AppendFormat(IFormatProvider provider, String format, Object[] args)
    //       at System.IO.TextWriter.WriteLine(String format, Object arg0)
    //       at System.IO.TextWriter.SyncTextWriter.WriteLine(String format, Object arg0)
    //       at Example.Main()
    
    Module Example
       Public Sub Main()
          Dim price As Decimal = 169.32d
          Console.WriteLine("The cost is {0:Q2}.", price)
       End Sub
    End Module
    ' The example displays the following output:
    '    Unhandled Exception: System.FormatException: Format specifier was invalid.
    '       at System.Number.FormatDecimal(Decimal value, String format, NumberFormatInfo info)
    '       at System.Decimal.ToString(String format, IFormatProvider provider)
    '       at System.Text.StringBuilder.AppendFormat(IFormatProvider provider, String format, Object[] args)
    '       at System.IO.TextWriter.WriteLine(String format, Object arg0)
    '       at System.IO.TextWriter.SyncTextWriter.WriteLine(String format, Object arg0)
    '       at Example.Main()
    

    この例外は、コーディングエラーが発生した場合に発生します。This exception results from a coding error. エラーを修正するには、書式指定文字列を削除するか、有効な文字列を置き換えます。To correct the error, either remove the format string or substitute a valid one. 次の例では、無効な書式指定文字列を "C" (通貨) 書式指定文字列に置き換えることで、エラーを修正します。The following example corrects the error by replacing the invalid format string with the "C" (currency) format string.

    using System;
    
    public class Example
    {
       public static void Main()
       {
          decimal price = 169.32m;
          Console.WriteLine("The cost is {0:C2}.", price);
       }
    }
    // The example displays the following output:
    //    The cost is $169.32.
    
    Module Example
       Public Sub Main()
          Dim price As Decimal = 169.32d
          Console.WriteLine("The cost is {0:C2}.", price)
       End Sub
    End Module
    ' The example displays the following output:
    '   The cost is $169.32.
    

    例外は、書式指定文字列で指定されたパターンDateTime.ParseExactGuid.ParseExact厳密に準拠するように文字列を解析する必要があるやなどのメソッドを解析することによってスローすることもできます。 FormatExceptionA FormatException exception can also be thrown by parsing methods, such as DateTime.ParseExact and Guid.ParseExact, that require the string to be parsed to conform exactly to the pattern specified by a format string. 次の例では、GUID の文字列表現が "G" 標準書式指定文字列によって指定されたパターンに準拠していると想定されています。In the following example, the string representation of a GUID is expected to conform to the pattern specified by the "G" standard format string. ただし、 GuidIFormattable構造体の実装では、"G" 書式指定文字列はサポートされていません。However, the Guid structure's implementation of IFormattable does not support the "G" format string.

    using System;
    
    public class Example
    {
       public static void Main()
       {
          string guidString = "ba748d5c-ae5f-4cca-84e5-1ac5291c38cb";
          Console.WriteLine(Guid.ParseExact(guidString, "G"));
       }
    }
    // The example displays the following output:
    //    Unhandled Exception: System.FormatException: 
    //       Format String can be only "D", "d", "N", "n", "P", "p", "B", "b", "X" or "x".
    //       at System.Guid.ParseExact(String input, String format)
    //       at Example.Main()
    
    Module Example
       Public Sub Main()
          Dim guidString As String = "ba748d5c-ae5f-4cca-84e5-1ac5291c38cb"
          Console.WriteLine(Guid.ParseExact(guidString, "G"))
       End Sub
    End Module
    ' The example displays the following output:
    '    Unhandled Exception: System.FormatException: 
    '       Format String can be only "D", "d", "N", "n", "P", "p", "B", "b", "X" or "x".
    '       at System.Guid.ParseExact(String input, String format)
    '       at Example.Main()
    

    この例外は、コードエラーによっても発生します。This exception also results from a coding error. これを修正するには、やDateTime.Parse Guid.Parseなどの正確な形式を必要としない解析メソッドを呼び出すか、または有効な書式指定文字列に置き換えます。To correct it, call a parsing method that doesn't require a precise format, such as DateTime.Parse or Guid.Parse, or substitute a valid format string. 次の例では、 Guid.Parseメソッドを呼び出してエラーを修正します。The following example corrects the error by calling the Guid.Parse method.

    using System;
    
    public class Example
    {
       public static void Main()
       {
          string guidString = "ba748d5c-ae5f-4cca-84e5-1ac5291c38cb";
          Console.WriteLine(Guid.Parse(guidString));
       }
    }
    // The example displays the following output:
    //    ba748d5c-ae5f-4cca-84e5-1ac5291c38cb
    
    Module Example
       Public Sub Main()
          Dim guidString As String = "ba748d5c-ae5f-4cca-84e5-1ac5291c38cb"
          Console.WriteLine(Guid.Parse(guidString))
       End Sub
    End Module
    ' The example displays the following output:
    '   ba748d5c-ae5f-4cca-84e5-1ac5291c38cb
    
  • 複合書式指定文字列の書式項目の1つ以上のインデックスが、オブジェクトリストまたはパラメーター配列内の項目のインデックスより大きくなっています。One or more of the indexes of the format items in a composite format string is greater than the indexes of the items in the object list or parameter array. 次の例では、書式指定文字列の書式項目の最大インデックスは3です。In the following example, the largest index of a format item in the format string is 3. オブジェクトリスト内の項目のインデックスは0から始まるため、この書式指定文字列では、オブジェクトリストに4つの項目を含める必要があります。Because the indexes of items in the object list are zero-based, this format string would require the object list to have four items. 代わりに、 dat3 つの、 temp、、およびscaleが含まれているので、 FormatExceptionコードは実行時に例外を生成します。Instead, it has only three, dat, temp, and scale, so the code results in a FormatException exception at run time:.

    using System;
    
    public class Example
    {
       public enum TemperatureScale 
       { Celsius, Fahrenheit, Kelvin }
    
       public static void Main()
       {
          String info = GetCurrentTemperature();
          Console.WriteLine(info);
       }
    
       private static String GetCurrentTemperature()
       {
          DateTime dat = DateTime.Now;
          Decimal temp = 20.6m;
          TemperatureScale scale = TemperatureScale.Celsius;
          String result;
          
          result = String.Format("At {0:t} on {1:D}, the temperature is {2:F1} {3:G}",
                                 dat, temp, scale);    
          return result;
       }
    }
    // The example displays output like the following:
    //    Unhandled Exception: System.FormatException: Format specifier was invalid.
    //       at System.Number.FormatDecimal(Decimal value, String format, NumberFormatInfo info)
    //       at System.Decimal.ToString(String format, IFormatProvider provider)
    //       at System.Text.StringBuilder.AppendFormat(IFormatProvider provider, String format, Object[] args)
    //       at System.String.Format(IFormatProvider provider, String format, Object[] args)
    //       at Example.Main()
    
    Module Example
       Public Enum TemperatureScale As Integer
          Celsius
          Fahrenheit
          Kelvin
       End Enum
    
       Public Sub Main()
          Dim info As String = GetCurrentTemperature()
          Console.WriteLine(info)
       End Sub
    
       Private Function GetCurrentTemperature() As String
          Dim dat As Date = Date.Now
          Dim temp As Decimal = 20.6d
          Dim scale As TemperatureScale = TemperatureScale.Celsius
          Dim result As String 
          
          result = String.Format("At {0:t} on {1:D}, the temperature is {2:F1} {3:G}",
                                 dat, temp, scale)    
          Return result
       End Function
    End Module
    ' The example displays output like the following:
    '    Unhandled Exception: System.FormatException: Format specifier was invalid.
    '       at System.Number.FormatDecimal(Decimal value, String format, NumberFormatInfo info)
    '       at System.Decimal.ToString(String format, IFormatProvider provider)
    '       at System.Text.StringBuilder.AppendFormat(IFormatProvider provider, String format, Object[] args)
    '       at System.String.Format(IFormatProvider provider, String format, Object[] args)
    '       at Example.Main()
    

    この場合、 FormatException例外は開発者エラーの結果です。In this case, the FormatException exception is a result of developer error. オブジェクトリストの各項目が書式指定項目try/catchのインデックスに対応していることを確認することで、ブロックで処理するのではなく、修正する必要があります。It should be corrected rather than handled in a try/catch block by making sure that each item in the object list corresponds to the index of a format item. この例を修正するには、 dat変数を参照する2番目の書式指定項目のインデックスを変更し、後続の各書式項目のインデックスを1つずつデクリメントします。To correct this example, change the index of the second format item to refer to the dat variable, and decrement the index of each subsequent format item by one.

    using System;
    
    public class Example
    {
       public enum TemperatureScale 
       { Celsius, Fahrenheit, Kelvin }
    
       public static void Main()
       {
          String info = GetCurrentTemperature();
          Console.WriteLine(info);
       }
    
       private static String GetCurrentTemperature()
       {
          DateTime dat = DateTime.Now;
          Decimal temp = 20.6m;
          TemperatureScale scale = TemperatureScale.Celsius;
          String result;
          
          result = String.Format("At {0:t} on {0:D}, the temperature is {1:F1} {2:G}",
                                 dat, temp, scale);    
          return result;
       }
    }
    // The example displays output like the following:
    //    At 10:40 AM on Wednesday, June 04, 2014, the temperature is 20.6 Celsius
    
    Module Example
       Public Enum TemperatureScale As Integer
          Celsius
          Fahrenheit
          Kelvin
       End Enum
    
       Public Sub Main()
          Dim info As String = GetCurrentTemperature()
          Console.WriteLine(info)
       End Sub
    
       Private Function GetCurrentTemperature() As String
          Dim dat As Date = Date.Now
          Dim temp As Decimal = 20.6d
          Dim scale As TemperatureScale = TemperatureScale.Celsius
          Dim result As String 
          
          result = String.Format("At {0:t} on {0:D}, the temperature is {1:F1} {2:G}",
                                 dat, temp, scale)    
          Return result
       End Function
    End Module
    ' The example displays output like the following:
    '       At 10:40 AM on Wednesday, June 04, 2014, the temperature is 20.6 Celsius
    
  • 複合書式指定文字列が整形式ではありません。The composite format string isn't well-formed. この場合、 FormatException例外は常に開発者エラーの結果になります。When this happens, the FormatException exception is always a result of developer error. これは、 try/catchブロックで処理されるのではなく、修正する必要があります。It should be corrected rather than handled in a try/catch block.

    次の例に示すように、リテラル中かっこを文字列に含めようとすると、例外がスローされます。Trying to include literal braces in a string, as the following example does, will throw the exception.

    result = String.Format("The text has {0} '{' characters and {1} '}' characters.",
                           nOpen, nClose);
    
    result = String.Format("The text has {0} '{' characters and {1} '}' characters.",
                           nOpen, nClose)
    

    複合書式指定文字列の中にリテラルかっこを含める場合の推奨される方法は、それらをオブジェクトリストに含め、書式項目を使用して結果文字列に挿入することです。The recommended technique for including literal braces in a composite format string is to include them in the object list and use format items to insert them into the result string. たとえば、次に示すように、前の複合書式指定文字列を変更できます。For example, you can modify the previous composite format string as shown here.

    string result;
    int nOpen = 1;
    int nClose = 2;
    result = String.Format("The text has {0} '{{' characters and {1} '}}' characters.",
                           nOpen, nClose);
    Console.WriteLine(result);
    
    result = String.Format("The text has {0} '{{' characters and {1} '}}' characters.",
                           nOpen, nClose)
    

    この例外は、書式指定文字列にタイプミスが含まれている場合にもスローされます。The exception is also thrown if your format string contains a typo. 次のメソッドのString.Format呼び出しでは、右中かっこを省略し、左中かっこと右角かっこを組み合わせています。The following call to the String.Format method omits a closing brace and pairs an opening brace with a closing bracket.

    int n1 = 10;
    int n2 = 20;
    String result = String.Format("{0 + {1] = {2}", 
                                  n1, n2, n1 + n2);
    
    Dim n1 As Integer = 10
    Dim n2 As Integer = 20
    Dim result As String = String.Format("{0 + {1] = {2}", 
                                         n1, n2, n1 + n2)
    

    エラーを修正するには、左中かっこと終わりかっこがすべて対応していることを確認します。To correct the error, ensure that all opening and closing braces correspond.

    String result = String.Format("{0} + {1} = {2}", 
                                  n1, n2, n1 + n2);
    
    Dim result As String = String.Format("{0} + {1} = {2}", 
                                         n1, n2, n1 + n2)
    
  • 厳密に型指定されたパラメーター配列としてオブジェクトリストを複合書式指定メソッドにFormatException指定したが、例外は、1つ以上の書式項目のインデックスがオブジェクトリスト内の引数の数を超えていることを示しています。You've supplied the object list in a composite formatting method as a strongly typed parameter array, and the FormatException exception indicates that the index of one or more format items exceeds the number of arguments in the object list. これは、配列型の間の明示的な変換が存在しないために、コンパイラが配列をパラメーター配列ではなく単一の引数として処理するためです。This occurs because no explicit conversion between array types exists, so instead the compiler treats the array as a single argument rather than as a parameter array. たとえば、メソッドのConsole.WriteLine(String, Object[])次の呼び出しではFormatException例外がスローされますが、書式項目の最大インデックスは3であり、型Int32のパラメーター配列には4つの要素があります。For example, the following call to the Console.WriteLine(String, Object[]) method throws a FormatException exception, although the highest index of the format items is 3, and the parameter array of type Int32 has four elements.

    using System;
    using System.Collections.Generic;
    
    public class Example
    {
       public static void Main()
       {
          Random rnd = new Random();
          int[]  numbers = new int[4];
          int total = 0;
          for (int ctr = 0; ctr <= 2; ctr++) {
             int number = rnd.Next(1001);
             numbers[ctr] = number;
             total += number;
          }   
          numbers[3] = total;
          Console.WriteLine("{0} + {1} + {2} = {3}", numbers);   
       }
    }
    // The example displays the following output:
    //    Unhandled Exception: 
    //    System.FormatException: 
    //       Index (zero based) must be greater than or equal to zero and less than the size of the argument list.
    //       at System.Text.StringBuilder.AppendFormat(IFormatProvider provider, String format, Object[] args)
    //       at System.IO.TextWriter.WriteLine(String format, Object arg0)
    //       at System.IO.TextWriter.SyncTextWriter.WriteLine(String format, Object arg0)
    //       at Example.Main()
    
    Imports System.Collections.Generic
    
    Module Example
       Public Sub Main()
          Dim rnd As New Random()
          Dim numbers(3) As Integer
          Dim total As Integer = 0
          For ctr = 0 To 2
             Dim number As Integer = rnd.Next(1001)
             numbers(ctr) = number
             total += number
          Next
          numbers(3) = total
          Console.WriteLine("{0} + {1} + {2} = {3}", numbers)   
       End Sub
    End Module
    ' The example displays the following output:
    '    Unhandled Exception: 
    '    System.FormatException: 
    '       Index (zero based) must be greater than or equal to zero and less than the size of the argument list.
    '       at System.Text.StringBuilder.AppendFormat(IFormatProvider provider, String format, Object[] args)
    '       at System.IO.TextWriter.WriteLine(String format, Object arg0)
    '       at System.IO.TextWriter.SyncTextWriter.WriteLine(String format, Object arg0)
    '       at Example.Main()
    

    この例外を処理するのではなく、その原因を排除する必要があります。Instead of handling this exception, you should eliminate its cause. Visual Basic もC#整数配列もオブジェクト配列に変換できないので、複合書式指定メソッドを呼び出す前に、変換を自分で実行する必要があります。Because neither Visual Basic nor C# can convert an integer array to an object array, you have to perform the conversion yourself before calling the composite formatting method. 次の例では、1つの実装を示します。The following example provides one implementation.

    using System;
    using System.Collections.Generic;
    
    public class Example
    {
       public static void Main()
       {
          Random rnd = new Random();
          int[]  numbers = new int[4];
          int total = 0;
          for (int ctr = 0; ctr <= 2; ctr++) {
             int number = rnd.Next(1001);
             numbers[ctr] = number;
             total += number;
          }   
          numbers[3] = total;
          object[] values = new object[numbers.Length];
          numbers.CopyTo(values, 0);
          Console.WriteLine("{0} + {1} + {2} = {3}", values);   
       }
    }
    // The example displays output like the following:
    //        477 + 956 + 901 = 2334
    
    Imports System.Collections.Generic
    
    Module Example
       Public Sub Main()
          Dim rnd As New Random()
          Dim numbers(3) As Integer
          Dim total As Integer = 0
          For ctr = 0 To 2
             Dim number As Integer = rnd.Next(1001)
             numbers(ctr) = number
             total += number
          Next
          numbers(3) = total
          Dim values(numbers.Length - 1) As Object
          numbers.CopyTo(values, 0) 
          Console.WriteLine("{0} + {1} + {2} = {3}", values)   
       End Sub
    End Module
    ' The example displays output like the following:
    '       477 + 956 + 901 = 2334
    

FormatExceptionでは、値0x80131537 を持つ HRESULT COR_E_FORMAT が使用されます。FormatException uses the HRESULT COR_E_FORMAT, which has the value 0x80131537.

クラスFormatExceptionはからException派生し、一意のメンバーを追加しません。The FormatException class derives from Exception and adds no unique members. FormatExceptionインスタンスの初期プロパティ値の一覧については、FormatExceptionコンストラクターを参照してください。For a list of initial property values for an instance of FormatException, see the FormatException constructors.

コンストラクター

FormatException()

FormatException クラスの新しいインスタンスを初期化します。Initializes a new instance of the FormatException class.

FormatException(SerializationInfo, StreamingContext)

シリアル化したデータを使用して、FormatException クラスの新しいインスタンスを初期化します。Initializes a new instance of the FormatException class with serialized data.

FormatException(String)

指定したエラー メッセージを使用して、FormatException クラスの新しいインスタンスを初期化します。Initializes a new instance of the FormatException class with a specified error message.

FormatException(String, Exception)

指定したエラー メッセージおよびこの例外の原因となった内部例外への参照を使用して、FormatException クラスの新しいインスタンスを初期化します。Initializes a new instance of the FormatException class with a specified error message and a reference to the inner exception that is the cause of this exception.

プロパティ

Data

例外に関する追加のユーザー定義情報を提供する、キー/値ペアのコレクションを取得します。Gets a collection of key/value pairs that provide additional user-defined information about the exception.

(継承元 Exception)
HelpLink

この例外に関連付けられているヘルプ ファイルへのリンクを取得または設定します。Gets or sets a link to the help file associated with this exception.

(継承元 Exception)
HResult

特定の例外に割り当てられているコード化数値である HRESULT を取得または設定します。Gets or sets HRESULT, a coded numerical value that is assigned to a specific exception.

(継承元 Exception)
InnerException

現在の例外の原因となる Exception インスタンスを取得します。Gets the Exception instance that caused the current exception.

(継承元 Exception)
Message

現在の例外を説明するメッセージを取得します。Gets a message that describes the current exception.

(継承元 Exception)
Source

エラーの原因となるアプリケーションまたはオブジェクトの名前を取得または設定します。Gets or sets the name of the application or the object that causes the error.

(継承元 Exception)
StackTrace

呼び出し履歴で直前のフレームの文字列形式を取得します。Gets a string representation of the immediate frames on the call stack.

(継承元 Exception)
TargetSite

現在の例外がスローされたメソッドを取得します。Gets the method that throws the current exception.

(継承元 Exception)

メソッド

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判定します。Determines whether the specified object is equal to the current object.

(継承元 Object)
GetBaseException()

派生クラスでオーバーライドされた場合、それ以後に発生する 1 つ以上の例外の主要な原因である Exception を返します。When overridden in a derived class, returns the Exception that is the root cause of one or more subsequent exceptions.

(継承元 Exception)
GetHashCode()

既定のハッシュ関数として機能します。Serves as the default hash function.

(継承元 Object)
GetObjectData(SerializationInfo, StreamingContext)

派生クラスでオーバーライドされた場合は、その例外に関する情報を使用して SerializationInfo を設定します。When overridden in a derived class, sets the SerializationInfo with information about the exception.

(継承元 Exception)
GetType()

現在のインスタンスのランタイム型を取得します。Gets the runtime type of the current instance.

(継承元 Exception)
MemberwiseClone()

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(継承元 Object)
ToString()

現在の例外の文字列形式を作成して返します。Creates and returns a string representation of the current exception.

(継承元 Exception)

イベント

SerializeObjectState

例外がシリアル化され、例外に関するシリアル化されたデータを含む例外状態オブジェクトが作成されたときに発生します。Occurs when an exception is serialized to create an exception state object that contains serialized data about the exception.

(継承元 Exception)

適用対象

こちらもご覧ください