《Effective java》读书笔记之二

原创 2004年06月27日 17:15:00

Methods Common to All Objects

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

item 7:当你覆盖equals方法的时候一定要遵守general contact

 

   覆盖equals的时候一定要加倍的小心,其实最好的办法就是不覆盖这个方法。比如在下面的情况下就可以不覆盖

   1这个类的每个实例都是唯一的,例如Thread

   2 如果你不关心这个类是否该提供一个测试逻辑相等的方法

   3超类已经覆盖了equals方法,并且它合适子类使用

   4如果这个类是private或者是package-private的,并且你确信他不会被调用

 

   但是当我们要为这个类提供区分逻辑相等和引用相等的方法的时候,我们就必须要覆盖这个方法了。例如String类,Date类等,覆盖的时候我们一定要遵从general contact,说白了就是一个合同。合同的主要内容是

   1x.equals(x)必须返回true

   2x.equalsy)当且仅当y.equals(x)返回true的时候返回true

   3x.equals(y)返回truey.equals(z)返回true,那么x.equals(z)必须返回true

   4.如果没有任何修改得话 那么多次调用x.equals(y)的返回值应该不变

   5.任何时候非空的对象x,x.equals(null)必须返回false

下面是作者的建议如何正确的覆盖equals方法

1.  ==检查是否参数就是这个对象的引用

2.  instanceof判断参数的类型是否正确

3.  把参数转换成合适的类型

4.  比较类的字段是不是匹配

例如:

public boolean equals(Object o)

{

       if(o== this) return true;

       if(!(o instanceof xxxx) return false;

       xxx in = (xxx)o;

       return ……..

}

最后一点要注意的时候不要提供这样的方法public boolean equals(MyClass o)这样是重载并不是覆盖Objectequals方法

item 8 :当你覆盖equals的时候必须覆盖hashCode方法

   这点必须切忌,不然在你和hash-based集合打交道的时候,错误就会出现了。关键问题在于一定要满足相等的对象必须要有相等的hashCode。如果你在PhoneNumber类中覆盖了equals方法,但是没有覆盖hashCode方法,那么当你做如下操作的时候就会出现问题了。

Map m = new HashMap();

m.put(new PhoneNumber(408,863,3334),”ming”)
当你调用m.get(new PhoneNumber(408,863,3334))的时候你希望得到ming但是你却得到了null,为什么呢因为在整个过程中有两个PhoneNumber的实例,一个是put一个是get,但是他们两个逻辑相等的实例却得到不同的hashCode那么怎么可以取得以前存入的ming呢。

 

Item 9:永远覆盖toString方法

ObjecttoString方法返回的形式是Class的类型加上@加上16进制的hashcode。你最好在自己的类中提供toString方法更好的表述实例的信息,不然别人怎么看得明白呢。

 

Item 10:覆盖clone()方法的时候一定要小心

一个对象要想被Clone,那么要实现Clone()接口,这个接口没有定义任何的方法,但是如果你不实现这个接口的话,调用clone方法的时候会出现CloneNotSupportedException,这就是作者叫做mixin的接口类型。通常clone()方法可以这样覆盖

public Object clone()

{

try
{

              return super.clone();

}

catch(CloneNotSupportedException e)
{}

}

但是当你要clone的类里面含有可修改的引用字段的时候,那么你一定要把整个类的蓝图进行复制,如果对你clone得到的对象进行修改的时候还会影响到原来的实例,那么这是不可取的。所以应该这样clone()

public Object clone() throws CloneNotSupportedException

{

       Stack Result  = (Stack)super.clone();

       Result.elements = (Object[])elements.clone();

       Return result;

}

其中elementsstack类中可修改的引用字段,注意如果elementsfinal的话我们就无能为力了,因为不能给他重新赋值了.其实如果不是必须的话,根本就不用它最好。

 

Item 11:考虑适当的时候覆盖Comparable接口

       Thinking in java上说的更清楚,这里不多少了。

《Effective java》—–读书笔记

2015年进步很小,看的书也不是很多,感觉自己都要废了,2016是沉淀的一年,在这一年中要不断学习、看书,努力提升自己!预计在2016年要看12本书,主要涉及java基础、Spring研究、java并...
  • chenssy
  • chenssy
  • 2016年05月04日 08:55
  • 10794

读书笔记_Effective C++_习惯C++

这是一本非常经典C++书籍,也是我在工作中发现自己C++上还有很多薄弱点的时候经常拿来充电的。这本书内容很多,讲了很多如何高效地使用C++的方法,有些地方自己也没能啃透,读过一遍后很多知识点容易忘记,...
  • John_cdy
  • John_cdy
  • 2015年05月04日 09:51
  • 2156

《More Effective C++》读书笔记-技术

25、将构造函数和非成员函数虚化1、这里所谓的虚拟构造函数,并不是真的指在构造函数前面加上 virtual 修饰符,而是指能够根据传入不同的参数建立不同继承关系类型的对象。class NLCompon...
  • will130
  • will130
  • 2016年05月02日 12:27
  • 2775

Effective C++读书笔记之二:尽量以const,enum,inline替换#define

Item2:Prefer consts,enums,and inlines to #defines
  • u013988279
  • u013988279
  • 2014年07月31日 15:57
  • 487

算法导论系列读书笔记之二

  • 2008年05月24日 23:01
  • 843KB
  • 下载

2002-12-11_USB读书笔记之二

  • 2011年04月05日 00:22
  • 177KB
  • 下载

Effective Java 2nd 读书笔记(思维导图)PDF版

  • 2015年09月29日 21:16
  • 18.65MB
  • 下载

《Effective Java》读书笔记

  • 2014年07月26日 23:56
  • 625KB
  • 下载

effective java 读书笔记

  • 2015年03月20日 12:01
  • 92KB
  • 下载

Effective Java 2nd 读书笔记(思维导图)

  • 2015年09月29日 20:47
  • 6.5MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:《Effective java》读书笔记之二
举报原因:
原因补充:

(最多只允许输入30个字)