Понимание IEquatable

Когда я реализую объекты, которые хочу сравнить, используя IEquatable<T> интерфейс:

  1. Почему мне нужно переопределить метод Equals(object), если я уже реализовал Equals(T)?
  2. Могу ли я использовать операторы == и != после внедрения IEquatable<T>?
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
52
0
20 841
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий
  1. От Статья MS Docs на IEquatable<T>:

    If you implement IEquatable<T>, you should also override the base class implementations of Equals(Object) and GetHashCode() so that their behavior is consistent with that of the Equals(T) method. If you do override Equals(Object), your overridden implementation is also called in calls to the static Equals(Object, Object) method on your class. In addition, you should overload the op_Equality and op_Inequality operators. This ensures that all tests for equality return consistent results.

  2. Нет, операторы не используют метод Equals. Для этого они должны быть перегружен отдельно.

поэтому, когда вы имеете дело с объектами, предполагается, что == означает только один и тот же адрес памяти (тот же экземпляр)

leora 04.01.2009 22:21

Довольно много. Подробнее здесь: msdn.microsoft.com/en-us/library/53k8ybth(VS.80).aspx

Ray Booysen 04.01.2009 22:23

Нет, используйте для этого ReferenceEquals (). Оператор равенства (==) обычно означает то же самое, но его можно переопределить (например, для строк и т.п.).

Paul-Jan 04.01.2009 22:26

Небольшая поправка к терминологии - операторы отвергать нельзя, но можно перегрузка.

Jon Skeet 04.01.2009 22:33

Да, вы можете перегрузить == и! = В и использовать их вместе с интерфейсом IEquatable. Но это нужно делать вручную, это не происходит автоматически с IEquatable. «Нет» во второй части ответа на самом деле неверен. Примечание. Пытался отредактировать ответ, но, по-видимому, некоторые думают, что неправильный ответ с наивысшей оценкой не является достаточной причиной для утверждения исправления.

AlexKven 25.08.2016 20:19

@AlexKven Готово! Дело не в том, что такое редактирование не следует делать; это то, что вы ожидаете, что рецензенты повторно проведут ваше собственное исследование, чтобы проверить ваши изменения. Иногда они могут даже не быть знакомы с рассматриваемым языком программирования.

jpaugh 11.09.2018 20:11

1) Как сказал Рэй, переопределите Equals(object), чтобы обеспечить согласованность, когда метод вызывается из классов, которые не знают (статически), что вы реализуете IEquatable<T>. Например, неуниверсальные классы коллекций будут использовать Equals(object) для сравнений. Вы также должны переопределить GetHashCode().

2) Реализация IEquatable<T> не перегружает операторы == и! = Автоматически, но ничто не мешает вам сделать это, как это делает System.String. Однако вы должны четко задокументировать это, если вы это сделаете - и будьте осторожны при сравнении между другими типами ссылок (например, MyType и Object), которые по-прежнему будут использовать сравнение идентичности. Я подозреваю, что это не лучшая идея, если только это не будет очень интенсивно используемым типом в вашем коде, где все будут хорошо знакомы с ним а также, где синтаксический сахар перегрузки == действительно окажет положительное влияние на читаемость.

Джон, есть ли прирост производительности для типа реализации IEquatable <T>, используемого, например, в Collection <T>, вызывающем метод Contains?

Rauhotz 04.01.2009 23:04

Это позволит избежать кастинга, да. Для типов значений он также избегает упаковки и распаковки. См. Документацию для Collection <T> .Contains - он использует EqualityComparer <T> .Default, который будет использовать реализацию IEquatable <T>, если это возможно.

Jon Skeet 04.01.2009 23:12

Да, не рекомендуется перегружать operator == и! = Для обеспечения проверки равенства значений (по сравнению с проверкой равенства ссылок по умолчанию). В документации MSDN предлагается делать это только для неизменяемых типов. Также существуют проблемы, связанные с интерфейсами и перегрузкой операторов.

Zach Burlingame 08.04.2009 20:16

См. stackoverflow.com/questions/728434/… для получения дополнительной информации по обоим вопросам.

Zach Burlingame 08.04.2009 20:16

Другие вопросы по теме