ValueType.ToString メソッド


このインスタンスの完全修飾型名を返します。Returns the fully qualified type name of this instance.

 override System::String ^ ToString();
public override string ToString ();
override this.ToString : unit -> string
Public Overrides Function ToString () As String


完全修飾型名。The fully qualified type name.


@No__t-0 メソッドは、Object.ToString メソッドをオーバーライドし、値型に対して ToString メソッドの既定の実装を提供します。The ValueType.ToString method overrides the Object.ToString method and provides the default implementation of the ToString method for value types. (値型は、のC#@no__t 0 キーワードで定義された型であり、Visual Basic で Structure... End Structure コンストラクトによって定義されています)。ただし、機能的には、実装は Object.ToString の実装と同じです。メソッドは完全修飾型名を返します。(Value types are types defined by the struct keyword in C#, and by the Structure...End Structure construct in Visual Basic.) Functionally, however, the implementation is that same as that of Object.ToString: the method returns the fully qualified type name.

のC# struct キーワードによって定義される値型と、Visual Basic 内の Structure... End Structure コンストラクトは、通常、ValueType.ToString メソッドをオーバーライドして、より意味のある値型の文字列表現を提供します。Value types defined by the struct keyword in C# and the Structure...End Structure construct in Visual Basic typically override the ValueType.ToString method to provide a more meaningful string representation of the value type. この違いを次の例に示します。The following example illustrates the difference. この例では、2つの値型 (EmployeeAEmployeeB) を定義し、それぞれのインスタンスを作成し、その ToString メソッドを呼び出します。It defines two value types, EmployeeA and EmployeeB, creates an instance of each, and calls its ToString method. @No__t 0 構造体は ValueType.ToString メソッドをオーバーライドしないため、完全修飾型名のみが表示されます。Because the EmployeeA structure does not override the ValueType.ToString method, it displays only the fully qualified type name. 一方、@no__t 0 のメソッドでは、オブジェクトに関する意味のある情報が提供されます。The EmployeeB.ToString method, on the other hand, provides meaningful information about the object.

using System;
using Corporate.EmployeeObjects;

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

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
Imports Corporate.EmployeeObjects

Module Example
   Public Sub Main()
      Dim empA As New EmployeeA With { .Name = "Robert" }
      Dim empB = new EmployeeB With { .Name = "Robert" }
   End Sub
End Module

Namespace Corporate.EmployeeObjects
    Public Structure EmployeeA
         Public Property Name As String 
    End Structure
    Public Structure EmployeeB
         Public Property Name As String 

         Public Overrides Function ToString() As String 
              Return Name
         End Function
    End Structure  
End Namespace
' The example displays the following output:
'     Corporate.EmployeeObjects.EmployeeA
'     Robert

列挙型も値型であることに注意してくださいが、ValueType.ToString をオーバーライドする @no__t 0 クラスから派生することに注意してください。Note that, although enumeration types are also value types, they derive from the Enum class, which overrides ValueType.ToString.

Windows ランタイムのメモNotes for the Windows Runtime

@No__t-1 の構造体で ToString メソッドを呼び出すと、ToString をオーバーライドしない値型の既定の動作が提供されます。When you call the ToString method on a Windows ランタイムWindows Runtime structure, it provides the default behavior for value types that don't override ToString. これは、.NET Framework が @no__t 0 に対して提供するサポートの一部です (「 Windows ストアアプリと Windows ランタイムの .NET Framework サポート」を参照してください)。This is part of the support that the .NET Framework provides for the Windows ランタイムWindows Runtime (see .NET Framework Support for Windows Store Apps and Windows Runtime). @no__t 0 の構造体は、メソッドを持つことができないため、 C#または Visual Basic で記述されている場合でも、@no__t をオーバーライドすることはできません。Windows ランタイムWindows Runtime structures can't override ToString, even if they're written with C# or Visual Basic, because they can't have methods. (さらに、@no__t 0 の構造体は ValueType を継承しません)。ただし、これらのメソッドをC#または Visual Basic コードで使用すると、ToStringEqualsGetHashCode の各メソッドがあるように見えます。また、.NET Framework には、これらのメソッドの既定の動作が用意されています。(In addition, structures in the Windows ランタイムWindows Runtime itself don't inherit ValueType.) However, they appear to have ToString, Equals, and GetHashCode methods when you use them in your C# or Visual Basic code, and the .NET Framework provides the default behavior for these methods.