UInt32.Equals メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
対象のインスタンスが、指定したオブジェクトまたは UInt32 に等しいかどうかを示す値を返します。
オーバーロード
Equals(Object) |
このインスタンスが指定されたオブジェクトに等しいかどうかを示す値を返します。 |
Equals(UInt32) |
このインスタンスが、指定した UInt32 に等しいかどうかを示す値を返します。 |
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
このインスタンスと比較するオブジェクト。
戻り値
obj
が UInt32 のインスタンスで、このインスタンスの値に等しい場合は true
。それ以外の場合は false
。
例
次のコード例は、メソッドを示して Equals います。
UInt32 myVariable1 = 20;
UInt32 myVariable2 = 20;
// Display the declaring type.
Console::WriteLine( "\nType of 'myVariable1' is '{0}' and value is : {1}", myVariable1.GetType(), myVariable1 );
Console::WriteLine( "Type of 'myVariable2' is '{0}' and value is : {1}", myVariable2.GetType(), myVariable2 );
// Compare 'myVariable1' instance with 'myVariable2' Object.
if ( myVariable1.Equals( myVariable2 ) )
Console::WriteLine( "\nStructures 'myVariable1' and 'myVariable2' are equal" );
else
Console::WriteLine( "\nStructures 'myVariable1' and 'myVariable2' are not equal" );
UInt32 myVariable1 = 20;
UInt32 myVariable2 = 20;
// Display the declaring type.
Console.WriteLine("\nType of 'myVariable1' is '{0}' and"+
" value is :{1}",myVariable1.GetType(), myVariable1);
Console.WriteLine("Type of 'myVariable2' is '{0}' and"+
" value is :{1}",myVariable2.GetType(), myVariable2);
// Compare 'myVariable1' instance with 'myVariable2' Object.
if( myVariable1.Equals( myVariable2 ) )
Console.WriteLine( "\nStructures 'myVariable1' and "+
"'myVariable2' are equal");
else
Console.WriteLine( "\nStructures 'myVariable1' and "+
"'myVariable2' are not equal");
Dim myVariable1 As UInt32 = UInt32.Parse(20)
Dim myVariable2 As UInt32 = UInt32.Parse(20)
' Display the declaring type.
Console.WriteLine(ControlChars.NewLine + "Type of 'myVariable1' is '{0}' and" + _
" value is :{1}", myVariable1.GetType().ToString(), myVariable1.ToString())
Console.WriteLine("Type of 'myVariable2' is '{0}' and" + _
" value is :{1}", myVariable2.GetType().ToString(), myVariable2.ToString())
' Compare 'myVariable1' instance with 'myVariable2' Object.
If myVariable1.Equals(myVariable2) Then
Console.WriteLine(ControlChars.NewLine + "Structures 'myVariable1' and" + _
" 'myVariable2' are equal")
Else
Console.WriteLine(ControlChars.NewLine + "Structures 'myVariable1' and" + _
" 'myVariable2' are not equal")
End If
注意 (呼び出し元)
コンパイラのオーバーロードの解決では、2つのメソッドオーバーロードの動作の明らかな違いを考慮することができ Equals(UInt32) ます。 引数との間の暗黙の変換が定義されていて、 obj
UInt32 引数がとして型指定されていない場合 Object 、コンパイラは暗黙的な変換を実行し、メソッドを呼び出し Equals(UInt32) ます。 それ以外の場合は、メソッドを呼び出します。このメソッドは、 Equals(Object) false
obj
引数が値でない場合は常にを返し UInt32 ます。 次の例は、2つのメソッドオーバーロード間の動作の違いを示しています。 との値の場合、最初の比較では、 Byte UInt16 コンパイラが true
自動的に拡大変換を実行して Equals(UInt32) メソッドを呼び出します。一方、2番目の比較では、 false
コンパイラがメソッドを呼び出すため、が返され Equals(Object) ます。
using System;
public class Example
{
static uint value = 112;
public static void Main()
{
byte byte1= 112;
Console.WriteLine("value = byte1: {0,16}", value.Equals(byte1));
TestObjectForEquality(byte1);
short short1 = 112;
Console.WriteLine("value = short1: {0,17}", value.Equals(short1));
TestObjectForEquality(short1);
long long1 = 112;
Console.WriteLine("value = long1: {0,18}", value.Equals(long1));
TestObjectForEquality(long1);
sbyte sbyte1 = 112;
Console.WriteLine("value = sbyte1: {0,17}", value.Equals(sbyte1));
TestObjectForEquality(sbyte1);
ushort ushort1 = 112;
Console.WriteLine("value = ushort1: {0,16}", value.Equals(ushort1));
TestObjectForEquality(ushort1);
ulong ulong1 = 112;
Console.WriteLine("value = ulong1: {0,18}", value.Equals(ulong1));
TestObjectForEquality(ulong1);
decimal dec1 = 112m;
Console.WriteLine("value = dec1: {0,21}", value.Equals(dec1));
TestObjectForEquality(dec1);
double dbl1 = 112;
Console.WriteLine("value = dbl1: {0,20}", value.Equals(dbl1));
TestObjectForEquality(dbl1);
}
private static void TestObjectForEquality(Object obj)
{
Console.WriteLine("{0} ({1}) = {2} ({3}): {4}\n",
value, value.GetType().Name,
obj, obj.GetType().Name,
value.Equals(obj));
}
}
// The example displays the following output:
// value = byte1: True
// 112 (UInt32) = 112 (Byte): False
//
// value = short1: False
// 112 (UInt32) = 112 (Int16): False
//
// value = long1: False
// 112 (UInt32) = 112 (Int64): False
//
// value = sbyte1: False
// 112 (UInt32) = 112 (SByte): False
//
// value = ushort1: True
// 112 (UInt32) = 112 (UInt16): False
//
// value = ulong1: False
// 112 (UInt32) = 112 (UInt64): False
//
// value = dec1: False
// 112 (UInt32) = 112 (Decimal): False
//
// value = dbl1: False
// 112 (UInt32) = 112 (Double): False
こちらもご覧ください
適用対象
Equals(UInt32)
このインスタンスが、指定した UInt32 に等しいかどうかを示す値を返します。
public:
virtual bool Equals(System::UInt32 obj);
public bool Equals (uint obj);
override this.Equals : uint32 -> bool
Public Function Equals (obj As UInteger) As Boolean
パラメーター
- obj
- UInt32
このインスタンスと比較する値。
戻り値
obj
の値がこのインスタンスと同じ場合は true
。それ以外の場合は false
。
実装
注釈
このメソッドは、 System.IEquatable<T> インターフェイスを実装し、 Equals(Object) パラメーターをオブジェクトに変換する必要がないため、メソッドよりも若干優れてい obj
ます。
注意 (呼び出し元)
コンパイラのオーバーロードの解決では、2つのメソッドオーバーロードの動作の明らかな違いを考慮することができ Equals(UInt32) ます。 引数との間の暗黙の変換が定義されていて、 obj
UInt32 引数がとして型指定されていない場合 Object 、コンパイラは暗黙的な変換を実行し、メソッドを呼び出し Equals(UInt32) ます。 それ以外の場合は、メソッドを呼び出します。このメソッドは、 Equals(Object) false
obj
引数が値でない場合は常にを返し UInt32 ます。 次の例は、2つのメソッドオーバーロード間の動作の違いを示しています。 との値の場合、最初の比較では、 Byte UInt16 コンパイラが true
自動的に拡大変換を実行して Equals(UInt32) メソッドを呼び出します。一方、2番目の比較では、 false
コンパイラがメソッドを呼び出すため、が返され Equals(Object) ます。
using System;
public class Example
{
static uint value = 112;
public static void Main()
{
byte byte1= 112;
Console.WriteLine("value = byte1: {0,16}", value.Equals(byte1));
TestObjectForEquality(byte1);
short short1 = 112;
Console.WriteLine("value = short1: {0,17}", value.Equals(short1));
TestObjectForEquality(short1);
long long1 = 112;
Console.WriteLine("value = long1: {0,18}", value.Equals(long1));
TestObjectForEquality(long1);
sbyte sbyte1 = 112;
Console.WriteLine("value = sbyte1: {0,17}", value.Equals(sbyte1));
TestObjectForEquality(sbyte1);
ushort ushort1 = 112;
Console.WriteLine("value = ushort1: {0,16}", value.Equals(ushort1));
TestObjectForEquality(ushort1);
ulong ulong1 = 112;
Console.WriteLine("value = ulong1: {0,18}", value.Equals(ulong1));
TestObjectForEquality(ulong1);
decimal dec1 = 112m;
Console.WriteLine("value = dec1: {0,21}", value.Equals(dec1));
TestObjectForEquality(dec1);
double dbl1 = 112;
Console.WriteLine("value = dbl1: {0,20}", value.Equals(dbl1));
TestObjectForEquality(dbl1);
}
private static void TestObjectForEquality(Object obj)
{
Console.WriteLine("{0} ({1}) = {2} ({3}): {4}\n",
value, value.GetType().Name,
obj, obj.GetType().Name,
value.Equals(obj));
}
}
// The example displays the following output:
// value = byte1: True
// 112 (UInt32) = 112 (Byte): False
//
// value = short1: False
// 112 (UInt32) = 112 (Int16): False
//
// value = long1: False
// 112 (UInt32) = 112 (Int64): False
//
// value = sbyte1: False
// 112 (UInt32) = 112 (SByte): False
//
// value = ushort1: True
// 112 (UInt32) = 112 (UInt16): False
//
// value = ulong1: False
// 112 (UInt32) = 112 (UInt64): False
//
// value = dec1: False
// 112 (UInt32) = 112 (Decimal): False
//
// value = dbl1: False
// 112 (UInt32) = 112 (Double): False