Complex.Equals Metoda

Definicja

Zwraca wartość wskazującą, czy dwie liczby zespolone są równe.Returns a value that indicates whether two complex numbers are equal.

Przeciążenia

Equals(Complex)

Zwraca wartość wskazującą, czy bieżące wystąpienie i określona liczba złożona mają tę samą wartość.Returns a value that indicates whether the current instance and a specified complex number have the same value.

Equals(Object)

Zwraca wartość wskazującą, czy bieżące wystąpienie i określony obiekt mają tę samą wartość.Returns a value that indicates whether the current instance and a specified object have the same value.

Equals(Complex)

Zwraca wartość wskazującą, czy bieżące wystąpienie i określona liczba złożona mają tę samą wartość.Returns a value that indicates whether the current instance and a specified complex number have the same value.

public:
 virtual bool Equals(System::Numerics::Complex value);
public bool Equals (System.Numerics.Complex value);
override this.Equals : System.Numerics.Complex -> bool
Public Function Equals (value As Complex) As Boolean

Parametry

value
Complex

Liczba zespolona do porównania.The complex number to compare.

Zwraca

trueJeśli ta liczba złożona i value ma tę samą wartość; falsew przeciwnym razie.true if this complex number and value have the same value; otherwise, false.

Implementuje

Uwagi

Metoda zapewnia implementację Complexstruktury. IEquatable<T> Equals(Complex)The Equals(Complex) method provides the IEquatable<T> implementation for the Complex structure. Jest wykonywane nieco lepiej niż Equals(Object) Metoda, ponieważ nie musi skonwertować jej parametru na liczbę zespoloną.It performs slightly better than Equals(Object) method because it does not have to convert its parameter to a complex number.

Dwie liczby zespolone są równe, jeśli ich rzeczywiste części są równe, a ich części urojone są równe.Two complex numbers are equal if their real parts are equal and their imaginary parts are equal. Equals(Complex) Metoda jest równoważna z następującym wyrażeniem:The Equals(Complex) method is equivalent to the following expression:

return this.Real.Equals(value) && this.Imaginary.Equals(value);      
Return Me.Real.Equals(value.Real) AndAlso Me.Imaginary.Equals(value.Imaginary)

Uwagi dotyczące wywoływania

Equals(Complex) Użyj metody z zachowaniem ostrożności, ponieważ dwie wartości, które są uważane za równoważne mogą być uznawane za nierówne ze względu na zróżnicowaną precyzję ich rzeczywistych i urojonych składników.Use the Equals(Complex) method with caution, because two values that are apparently equivalent can be considered unequal due to the differing precision of their real and imaginary components. Następujące przykładowe raporty (3,33333, 0,142857) i (10/3, 1/7) nie są równe.The following example reports that (3.33333, 0.142857) and (10/3, 1/7) are not equal.

[!code-csharpSystem.Numerics.Complex.Equals#4] [!code-vbSystem.Numerics.Complex.Equals#4][!code-csharpSystem.Numerics.Complex.Equals#4] [!code-vbSystem.Numerics.Complex.Equals#4] Jedną z zalecanych technik jest zdefiniowanie akceptowalnego marginesu różnicy między tymi dwiema wartościami (na przykład .01% jednego z wartości rzeczywistych i urojonych) zamiast porównywania wartości dla równości.One recommended technique is to define an acceptable margin of difference between the two values (such as .01% of one of the values' real and imaginary components) instead of comparing the values for equality. Jeśli wartość bezwzględna różnicy między dwoma wartościami jest mniejsza lub równa marginesowi, różnica jest prawdopodobnie spowodowana różnicą precyzji i dlatego wartości mogą być równe.If the absolute value of the difference between the two values is less than or equal to that margin, the difference is likely to be due to a difference in precision, and, therefore, the values are likely to be equal. Poniższy przykład korzysta z tej techniki, aby porównać dwie wartości złożone, których poprzedni przykład kodu nie jest równy.The following example uses this technique to compare the two complex values that the previous code example found to be unequal. Znaleziono dwie liczby zespolone jako równe.It finds the two complex numbers to be equal.

[!code-csharpSystem.Numerics.Complex.Equals#5] [!code-vbSystem.Numerics.Complex.Equals#5][!code-csharpSystem.Numerics.Complex.Equals#5] [!code-vbSystem.Numerics.Complex.Equals#5]

Zobacz też

Equals(Object)

Zwraca wartość wskazującą, czy bieżące wystąpienie i określony obiekt mają tę samą wartość.Returns a value that indicates whether the current instance and a specified object have the same value.

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

Parametry

obj
Object

Obiekt do porównania.The object to compare.

Zwraca

truefalse Complex Complex Jeśli parametr jest obiektem lub typem umożliwiającym niejawną konwersję do obiektu, a jego wartość jest równa bieżącemu obiektowi; w przeciwnym razie,. Complex objtrue if the obj parameter is a Complex object or a type capable of implicit conversion to a Complex object, and its value is equal to the current Complex object; otherwise, false.

Uwagi

Dwie liczby zespolone są równe, jeśli ich rzeczywiste części są równe, a ich części urojone są równe.Two complex numbers are equal if their real parts are equal and their imaginary parts are equal. Equals(Object) Metoda jest równoważna z następującym wyrażeniem:The Equals(Object) method is equivalent to the following expression:

return this.Real.Equals(((Complex) value).Real) && 
       this.Imaginary.Equals(((Complex) value).Imaginary);
Return Me.Real.Equals(CType(value, Complex).Real) AndAlso 
       Me.Imaginary.Equals(CType(value, Complex).Imaginary)

Complex Equals(Object) obj Jeśli parametr nie jest obiektem,alejesttypemdanych,dlaktóregozdefiniowanoniejawnąkonwersję,Metodakonwertujedoobiektu,któregoczęśćrzeczywistajestrównawartościComplex obj obji których część urojona jest równa zero przed przeprowadzeniem porównania.If the obj parameter is not a Complex object, but it is a data type for which an implicit conversion is defined, the Equals(Object) method converts obj to a Complex object whose real part is equal to the value of obj and whose imaginary part is equal to zero before it performs the comparison. Poniższy przykład ilustruje to poprzez znalezienie, że liczba zespolona i wartość zmiennoprzecinkową o podwójnej precyzji są równe.The following example illustrates this by finding that a complex number and a double-precision floating-point value are equal.

double n1 = 16.33;
System.Numerics.Complex c1 = 
       new System.Numerics.Complex(16.33, 0);
Console.WriteLine(c1.Equals(n1));               // Returns true.
Dim n1 As Double = 16.33
Dim c1 As New System.Numerics.Complex(16.33, 0)
Console.WriteLine(c1.Equals(n1))                ' Returns True.

Uwagi dotyczące wywoływania

Equals(Complex) Użyj metody z zachowaniem ostrożności, ponieważ dwie wartości, które są uważane za równoważne mogą być uznawane za nierówne ze względu na zróżnicowaną precyzję ich rzeczywistych i urojonych składników.Use the Equals(Complex) method with caution, because two values that are apparently equivalent can be considered unequal due to the differing precision of their real and imaginary components. Problem może być accentuated, jeśli obj musi zostać przekonwertowany na Double a przed przeprowadzeniem porównania.The problem can be accentuated if obj must be converted to a Double before performing the comparison. Poniższy przykład porównuje liczbę zespoloną, której prawdziwy składnik wydaje się być równy Single wartości tej Single wartości.The following example compares a complex number whose real component appears to be equal to a Single value with that Single value. Jak widać, porównanie dla zwracanych Falsedanych.As the output shows, the comparison for equality returns False.

[!code-csharpSystem.Numerics.Complex.Equals#8] [!code-vbSystem.Numerics.Complex.Equals#8][!code-csharpSystem.Numerics.Complex.Equals#8] [!code-vbSystem.Numerics.Complex.Equals#8] Jedną z zalecanych technik jest zdefiniowanie akceptowalnego marginesu różnicy między tymi dwiema wartościami (na przykład .01% jednego z wartości rzeczywistych i urojonych) zamiast porównywania wartości dla równości.One recommended technique is to define an acceptable margin of difference between the two values (such as .01% of one of the values' real and imaginary components) instead of comparing the values for equality. Jeśli wartość bezwzględna różnicy między dwoma wartościami jest mniejsza lub równa marginesowi, różnica jest prawdopodobnie spowodowana różnicą precyzji i dlatego wartości mogą być równe.If the absolute value of the difference between the two values is less than or equal to that margin, the difference is likely to be due to a difference in precision and, therefore, the values are likely to be equal. Poniższy przykład korzysta z tej techniki, aby porównać dwie wartości, które nie zostały odnalezione przez poprzedni przykład kodu.The following example uses this technique to compare the two values that the previous code example found to be unequal. Teraz znajdzie je na równe.It now finds them to be equal.

[!code-csharpSystem.Numerics.Complex.Equals#7] [!code-vbSystem.Numerics.Complex.Equals#7][!code-csharpSystem.Numerics.Complex.Equals#7] [!code-vbSystem.Numerics.Complex.Equals#7]

Dotyczy