欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#中的 == 和equals()区别浅析

程序员文章站 2024-01-24 12:40:16
首先看看,如以下代码: int age = 25; short newage = 25; console.writeline(age == newage)...

首先看看,如以下代码:

int age = 25; 
short newage = 25; 
console.writeline(age == newage); //true 
console.writeline(newage.equals(age)); //false 
console.readline();

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

简而言之:“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。

这里是实际中使用的equals():

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#中的 == 和equals()的区别有所了解了,希望这篇文章对大家的学习有所帮助。