马上加入IBC程序猿 各种源码随意下,各种教程随便看! 注册 每日签到 加入编程讨论群

C#教程 ASP.NET教程 C#视频教程程序源码享受不尽 C#技术求助 ASP.NET技术求助

【源码下载】 社群合作 申请版主 程序开发 【远程协助】 每天乐一乐 每日签到 【承接外包项目】 面试-葵花宝典下载

官方一群:

官方二群:

C#中equals()跟==的区别

[复制链接]
查看3939 | 回复2 | 2014-5-6 10:06:35 | 显示全部楼层 |阅读模式
示例代码:
[C#] 纯文本查看 复制代码
int age = 25;
 
short newAge = 25;
 
Console.WriteLine(age == newAge);  //true
 
Console.WriteLine(newAge.Equals(age)); //false
 
Console.ReadLine(); 



int和short为原始类型,但与“==”比较返回true,equals()比较返回false。为什么呢?

  Answers:
  简而言之:

  “equals()”相比“= =”复杂。
  具体来说:

  原始类型覆盖(override)基类的object.Equals(object),并且当括弧中的object与其类型和值相同时返回true (注意Nullable类型也适合上述判断;非空Nullable类型总是装箱到一个基础类型实例)。
  由于newAge是short,因此在object是short且值与newAge值相等时,newAge.Equals(object)返回true。你传递的是一个int对象,所以它返回false。
  相比之下,“= =”运算符被定义为带两个整形(int)或两个短整型(short)或两个长整形(long)的运算。当“= =”两个参数一个是整形和一个短整型时,编译器会隐式转换short为int,并比较转换后int值大小。
  使其工作其他方法:
  原始类型也有自己的equals()方法,equals接受相同的类型的参数。
  如果你写age.Equals(newAge),编译器将选择int.Equals(int)作为最好的重载(overload)方法且隐式转换short为int。然后,它会返回true,因为这种方法直接比较两个int值大小。
  short也有一个short.Equals(short)方法,但是int类型不能隐式转换为short,所以就不会调用它。
  你可以使用cast转换强制调用这个方法:

Console.Writeline(newAge.Equals((short)age)); //true




这将直接调用short.Equals(short),没有装箱操作。如果age大于32767,它会抛出一个溢出异常。
 你也可调用short.Equals(object)这个重载,但需要明确地传递一个经过装箱的具有相同类型的对象:




Console.WriteLine(newAge.Equals((object)(short)age)); // true




  像前面可选方法(short.Equals(short))一样,如果大小超过short范围,同样抛出一个溢出异常。不同于以往的解决方案,它将short装箱成一个object——浪费time和memory。

  Source Code:这里是实际中使用的Equals():

[C#] 纯文本查看 复制代码
public override bool Equals(Object obj) {
 
       if (!(obj is Int16)) {
 
           return false;
 
       }
 
       return m_value == ((Int16)obj).m_value;
 
   }
 
   public bool Equals(Int16 obj)
 
   {
 
       return m_value == obj;
 
   } 







相关帖子

C#论坛 www.ibcibc.com IBC编程社区
C#
C#论坛
IBC编程社区
飞/可爱朋 | 2014-5-7 23:24:43 | 显示全部楼层
学习
881966 | 2018-12-4 20:49:50 | 显示全部楼层
谢谢分享,学习学习
*滑块验证:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则