If the current instance is a reference type,the Equals(Object) method tests for reference equality,and a call to the @H_404_4@Equals(Object) method is equivalent to a call to the ReferenceEquals method.
那么为什么跟随代码导致两个不同的方法调用结果Equals方法返回True,而ReferenceEquals方法返回false,即使obj和obj1是引用类型,因为IsClass属性返回true.
using System;public class Program{ public static voID Main() { var obj = new { a = 1,b = 1 }; var obj1 = new { a = 1,b = 1 }; Console.Writeline("obj.IsClass: " + obj.GetType().IsClass); Console.Writeline("object.ReferenceEquals(obj,obj1): " + object.ReferenceEquals(obj,obj1)); Console.Writeline("obj.Equals(obj1): " + obj.Equals(obj1)); }}
输出:
解决方法 obj和obj1引用2个不同的对象,因此object.ReferenceEquals()将返回false.obj.IsClass: True
object.ReferenceEquals(obj,obj1): @H_404_4@False
obj.Equals(obj1): @H_404_4@True
Equals()返回true,因为编译器为匿名类型实现了Equals().如果两个对象的所有属性具有相同的值,它将返回true.
总结以上是内存溢出为你收集整理的c# – 即使变量是引用类型,为什么Equals和ReferenceEquals方法的结果也不同?全部内容,希望文章能够帮你解决c# – 即使变量是引用类型,为什么Equals和ReferenceEquals方法的结果也不同?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)