ValueType.GetHashCode メソッド

定義

このインスタンスのハッシュ コードを返します。

public:
 override int GetHashCode();
public override int GetHashCode ();
override this.GetHashCode : unit -> int
Public Overrides Function GetHashCode () As Integer

戻り値

Int32

このインスタンスのハッシュ コードである 32 ビット符号付き整数。

GetHashCode派生値の型によってメソッドをオーバーライドする方法を次の例に示します。

public ref struct Complex
{
public:
   double m_Re;
   double m_Im;
   virtual bool Equals( Object^ ob ) override
   {
      if ( dynamic_cast<Complex^>(ob) )
      {
         Complex^ c = dynamic_cast<Complex^>(ob);
         return m_Re == c->m_Re && m_Im == c->m_Im;
      }
      else
      {
         return false;
      }
   }

   virtual int GetHashCode() override
   {
      return m_Re.GetHashCode() ^ m_Im.GetHashCode();
   }
};
public struct Complex
{
    public double m_Re;
    public double m_Im;

    public override bool Equals( object ob ){
        if( ob is Complex ) {
            Complex c = (Complex) ob;
            return m_Re==c.m_Re && m_Im==c.m_Im;
        }
        else {
            return false;
        }
    }

    public override int GetHashCode(){
        return m_Re.GetHashCode() ^ m_Im.GetHashCode();
    }
}
Public Structure Complex
   Private m_Re As Double
   Private m_Im As Double
       
   Public Overloads Function Equals(ob As Object) As Boolean
      If TypeOf ob Is Complex Then
         Dim c As Complex = CType(ob, Complex)
         Return m_Re = c.m_Re And m_Im = c.m_Im
      Else
         Return False
      End If
   End Function
   
   
   Public Overloads Function GetHashCode() As Integer
      Return m_Re.GetHashCode() ^ m_Im.GetHashCode()
   End Function

End Structure

注釈

メソッドは、 GetHashCode から派生した型に適用され ValueType ます。 派生型の1つ以上のフィールドを使用して、戻り値を計算します。 派生型のメソッドを呼び出すと、 GetHashCode 戻り値は、ハッシュテーブルのキーとして使用するのに適していない可能性があります。 また、これらのフィールドの1つ以上の値が変更された場合、その戻り値は、ハッシュテーブルのキーとして使用するのに適していない可能性があります。 どちらの場合も、 GetHashCode 型のハッシュコードの概念をより厳密に表すメソッドの独自の実装を記述することを検討してください。

詳細については、「Object.GetHashCode」および「System.Collections.Hashtable」を参照してください。

Windows ランタイムのメモ

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

適用対象