///C#中的比较[==]操作
///Author:Deney
///ps:基础演示
object o1 ; //目标对象
object o2 ; //目标对象
o1 = 1; //目标对象赋值为
o2 = 1; //目标对象赋值为
///下面应该输出False
///因为非内置对象(class 对象)的默认== (指在未重载情况下的)为引用比较
///我觉得可以理解成指针地址比较;)
Console.WriteLine(o1 == o2);
///下面输出应为True
///因为当你用o1.GetType() 来检测类型的时候,你会发现它实际的类型还是Int32。
///这样一来,当你调用Equals 的时候调用的则为实际类型Int32 类型的Equals方法了,
///此时为值比较,自然为真
Console.WriteLine(o1.Equals(o2));
o1 = o2; //在这里,我直接将两个对象作= 运算;
///下面应该输出真,原因如上,因为此时o1,o2所指向的堆数据为同一地址,故相等;
///重点,内存中。o1,o2的地址不同,但地址指向的值(引用)相同
Console.WriteLine(o1 == o2);
///值不变,值比较依然不会变化,True;
Console.WriteLine(o1.Equals(o2));
o2 = 1;
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
Console.WriteLine("!!!!!!!!!!!!!!!!!!!!!!");
o1 = "1";
o2 = "1";
///这里很特殊,因为String为class对象,故string是堆存放的,
///输出为真因为== 实际上已经被string对象重载,故相等;
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
o1 = o2;
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
o2 = "1";
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
Console.WriteLine("!!!!!!!!!!!!!!!!!!!!!!");
o1 = new object();
o2 = new object();
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
o1 = o2;
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
o2 = new object();
Console.WriteLine(o1 == o2);
Console.WriteLine(o1.Equals(o2));
本文详细解析了C#中使用等号比较操作符`==`时的行为,特别是针对不同对象类型(内置类型与自定义类)时的区别。通过实例演示,解释了内置类型与非内置类型(类对象)比较时的引用与值比较,以及如何通过`Equals()`方法进行正确的对象比较。同时,文章还特别关注了对象引用之间的关系和赋值操作的影响。

被折叠的 条评论
为什么被折叠?



