Skip to main content

Why does default == implementation not call Equals?



Possible Duplicate:

Why ReferenceEquals and == operator behave different from Equals




The default implementation of == operator compares objects by references. So when you override Equals (which default behaviour is the same) you have to also specify == and != operators so that they call Equals (and make it in every class of hierarchy as == and != operators are not virtual).



My question is why it is so? Why does == and != compare objects by reference instead of using Equals? I guess there should be a reason for such a fundamental thing.



Update.



To comments: I assumed == should depend on Equals (but not vice versa) as you can override Equals in base class and use this implementation in derived classes automatically. It wouldn't work if Equals used == in its implementation, as == is not virtual.


Source: Tips4allCCNA FINAL EXAM

Comments

  1. I believe the main reason is == is a static operator and can be called on null objects while Equals requires an instance.

    For example:

    Foo foo1 = null;
    Foo foo2 = null;

    Console.WriteLine(foo1 == foo2); // cannot use Equals

    ReplyDelete
  2. Object.ReferenceEquals is a static member that compares reference equality. Even value types are boxed before being passed to that method.

    What about Equals, it's a virtual method, which means it lets to a consumer to override a functionality.

    So default implementation of == behavior presumes default comparison(reference) is ok for you, if you need something specific, in this case framework provides you with a virtual method, which can be overriden.

    ReplyDelete
  3. The "reason" is because sometimes one needs to know if A is the same instance as B as opposed to whether or not they are merely "equal" to each other.

    For example, two objects being equal to each other may make sense for most of your business logic, however, you may also need to utilize some concurrency utilities which do atomic operations where the results are dependent on object identity, not equality.

    ReplyDelete
  4. The == has been around and used for reference since C, and it's integrated into the language syntax rather than having to reply on method invocation (Even if results are the same for both).

    Simply, because C# is not Objective C :)

    ReplyDelete
  5. In Java, it is sometimes nice to quickly determine whether or not two identifiers are equal by simply comparing the references. == has it's place. If you look at an IDE generated equals method, you will often find that the first comparison made is reference equality, after all, why check the fields if the object references are the same?

    ReplyDelete
  6. I would call it a feature. By reference two identical objects are still two separate objects. If you override Equals then you can determine if two objects are identical. Even if two objects are identical I also might want to test if the are the same object. I often have reason to override equals but never had the need to override == != (but that language provides that option).

    With string they override == and I don't like it. Although string is a reference type, the equality operators (== and !=) are defined to compare the values of string objects, not references (7.9.7 String equality operators). This makes testing for string equality more intuitive. See the problem this introduced. WPF ListBox Scroll to the bottom

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.