国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

C# 中的 == 和 equals()有什么區別?

2019-11-17 03:12:04
字體:
來源:轉載
供稿:網友

C# 中的 == 和 equals()有什么區別?

如以下代碼:

123456789int age = 25;short newAge = 25;Console.WriteLine(age == newAge); //trueConsole.WriteLine(newAge.Equals(age)); //falseConsole.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轉換強制調用這個方法:

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

  這將直接調用short.Equals(short),沒有裝箱操作。如果age大于32767,它會拋出一個溢出異常。

  你也可調用short.Equals(object)這個重載,但需要明確地傳遞一個經過裝箱的具有相同類型的對象:

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

  像前面可選方法(short.Equals(short))一樣,如果大小超過short范圍,同樣拋出一個溢出異常。不同于以往的解決方案,它將short裝箱成一個object——浪費time和memory。

  Source Code:

  這里是實際中使用的Equals():

12345678910111213141516171819public 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;}

  擴展閱讀:

  見Eric Lippert.


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乌兰县| 年辖:市辖区| 临潭县| 马边| 平舆县| 蒙城县| 古蔺县| 镇江市| 富裕县| 宜阳县| 江北区| 古田县| 青川县| 澄迈县| 宜州市| 即墨市| 砀山县| 新营市| 龙游县| 炉霍县| 宁国市| 四川省| 韶山市| 巫溪县| 华容县| 龙门县| 白朗县| 四川省| 巴南区| 大余县| 文水县| 温宿县| 麻江县| 灵丘县| 济阳县| 阳原县| 腾冲县| 海城市| 内黄县| 青河县| 峡江县|