次の方法で共有


ValueType.Equals(Object) メソッド

定義

このインスタンスと指定したオブジェクトが等しいかどうかを示します。

public:
 override bool Equals(System::Object ^ obj);
public override bool Equals (object obj);
public override bool Equals (object? obj);
override this.Equals : obj -> bool
Public Overrides Function Equals (obj As Object) As Boolean

パラメーター

obj
Object

現在のインスタンスと比較するオブジェクト。

戻り値

true obj とこのインスタンスが同じ型であり、同じ値を表している場合です。それ以外の場合は、falseします。

次の例では、Equals メソッドを派生値型でオーバーライドする方法を示します。

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();
    }
}
type Complex() =
    member val m_Re = 0. with get, set
    member val m_Im = 0. with get, set

    override this.Equals(ob) =
        match ob with
        | :? Complex as c ->
            this.m_Re = c.m_Re && this.m_Im = c.m_Im
        | _ -> false
        
    override this.GetHashCode() =
        this.m_Re.GetHashCode() ^^^ this.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

注釈

ValueType.Equals(Object) メソッドは Object.Equals(Object) をオーバーライドし、.NET のすべての値型に対して値の等価性の既定の実装を提供します。

既定の実装では、現在のインスタンスの各フィールドで Object.Equals(Object) が呼び出され、obj され、すべてのフィールドが等しい場合は true が返されます。

.NET 9 以降では、InlineArrayAttribute が型に適用されている場合、ValueType.Equals(Object) の既定の実装では NotSupportedException がスローされます。

大事な

特に、値型に参照型のフィールドが含まれている場合は、Equals(Object) メソッドをオーバーライドする必要があります。 これにより、パフォーマンスが向上し、型の等価性の意味をより厳密に表すことができます。

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

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

適用対象