英語で読む

次の方法で共有


ValueType.ToString メソッド

定義

このインスタンスの完全修飾型名を返します。

public override string ToString ();
public override string? ToString ();

戻り値

完全修飾型名。

注釈

メソッドは ValueType.ToString メソッドを Object.ToString オーバーライドし、値型の メソッドの ToString 既定の実装を提供します。 (値型は、 によって定義される型です。structC# で、... でStructureをキーワード (keyword)します。End StructureVisual Basic のコンストラクト。)ただし、機能的には、 の実装と同じですObject.ToString。メソッドは完全修飾型名を返します。

C# のキーワード (keyword)と StructureVisual Basic の ...End Structure コンストラクトによって定義されるstruct値型は、通常、 メソッドをValueType.ToStringオーバーライドして、値型のより意味のある文字列表現を提供します。 この違いを次の例に示します。 2 つの値型 と を定義しEmployeeBEmployeeAそれぞれのインスタンスを作成し、そのメソッドをToString呼び出します。 構造体は メソッドをEmployeeAValueType.ToStringオーバーライドしないため、完全修飾型名のみが表示されます。 一方、 メソッドは EmployeeB.ToString オブジェクトに関する意味のある情報を提供します。

using System;
using Corporate.EmployeeObjects;

public class Example
{
   public static void Main()
   {
      var empA = new EmployeeA{ Name = "Robert",};
      Console.WriteLine(empA.ToString());
      
      var empB = new EmployeeB{ Name = "Robert",};
      Console.WriteLine(empB.ToString());
   }
}

namespace Corporate.EmployeeObjects
{
    public struct EmployeeA
    {
         public String Name { get; set; }
    }
    
    public struct EmployeeB
    {
         public String Name { get; set; }

         public override String ToString()
         {
              return Name;
         }
    }  
}
// The example displays the following output:
//     Corporate.EmployeeObjects.EmployeeA
//     Robert

列挙型は値型でもありますが、 をオーバーライドValueType.ToStringする Enum クラスから派生します。

Windows ランタイムに関する注意事項

Windows ランタイム構造体で メソッドを呼び出ToStringすと、 をオーバーライドToStringしない値型の既定の動作が提供されます。 これは、.NET がWindows ランタイムに対して提供するサポートの一部です (「.NET での Windows ストア アプリとWindows ランタイムのサポート」を参照してください)。 Windows ランタイム構造体は、C# または Visual Basic で記述されている場合でも、メソッドを持つことができないため、 をオーバーライドToStringすることはできません。 (さらに、Windows ランタイム自体の構造体は 継承ValueTypeされません)。ただし、C# または Visual Basic コードで使用すると、メソッドは 、Equals、および GetHashCode のように見ToStringえ、.NET ではこれらのメソッドの既定の動作が提供されます。

適用対象

製品 バージョン
.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.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0