[[Python-Dev] PyObject_RichCompareBool identity shortcut] About specializing comparing objects in collections
data:image/s3,"s3://crabby-images/135b7/135b745fcb50f0bcc827b93de23ee1213e1b844e" alt=""
Returning to the original topic post on the comparison of objects in containers ... Could be asked to enter a special method __equals__ of objects for comparison in containers (by default, if it is not defined - use usual method for compatibility), just as is done in C# (it's special object's method Equals is used to compare items in the collection). ----- Zaur
data:image/s3,"s3://crabby-images/6a9ad/6a9ad89a7f4504fbd33d703f493bf92e3c0cc9a9" alt=""
ZS wrote:
I'm not sure I understand what that would gain us, have I missed something? Currently, containers use identity tests as an optimization to avoid calling (potentially expensive) __eq__. What benefit do you have in mind to have containers call (potentially expensive) __equals__ instead of __eq__? It might help if you tell us what you envisage float would have as __equals__ instead of the current __eq__. -- Steven
data:image/s3,"s3://crabby-images/6a9ad/6a9ad89a7f4504fbd33d703f493bf92e3c0cc9a9" alt=""
ZS wrote:
I'm not sure I understand what that would gain us, have I missed something? Currently, containers use identity tests as an optimization to avoid calling (potentially expensive) __eq__. What benefit do you have in mind to have containers call (potentially expensive) __equals__ instead of __eq__? It might help if you tell us what you envisage float would have as __equals__ instead of the current __eq__. -- Steven
participants (2)
-
Steven D'Aprano
-
ZS