创建和销毁对象

》考虑用静态工厂方法替代构造器。

优点:

●优势在于有名称。

●不必再每次调用他们的时候都创建一个新的对象。

●可以返回原返回类型的任何子类型的对象。

●在创建参数化类型实例的时候,他们使代码更加简洁。

缺点:

●类如果不含公有的或者受保护的构造器。就不能被子类化。

●他们与其他的静态方法没有任何区别。

》遇到多个构造器参数的时候考虑用构建器。

》用私有的构造器或者枚举类型强化Singleton属性。

》通过私有构造器强化不可实例化的能力。

》避免创建不必要的对象

反面的例子

String s = new String("s");// do not this

●每次执行的时候都会创建一个新的实例。

改版

String s= "s";

●只有一个String实例。

》消除过期的对象引用。

●一旦对象引用已经过期,只需要清空这些引用即可。

●清空对象引用应该是一种例外,而不是一种规范的行为。

●只要是类自己管理内存,就应该警惕内存泄漏问题。

》避免使用终结方法

●终结方法(finalizer)是不可预测的,也是很危险的。一般的情况下是不必要的。

对所有对象都通用的方法

》覆盖equals时请遵守通用约定。

●类的每个实例本质上都是唯一的。

●不关心类是否提供了逻辑相等的测试功能。

●超类已经覆盖了Equals,从超类继承过来的行为对于子类也是合适的。

●类是私有的或是包私有的,可以确定他的equals方法永远不会被调用,这时,要覆盖,防止被意外的调用。

●自反性。

●对称性。

●传递性。

●一致性。

       类和接口

》使类与成员的可访问性最小化。

》在公有类中使用访问方法而非公有域。

》复合优先于继承。

》接口优于抽象类。

●现有的类可以很容易被更新,以实现新的接口。

》接口只用于定义类型。

●常量接口模式是对接口的不良使用。

》要尽可能的消除非受检警告。

》列表优先于数组。

●数组使具体化的,只有在运行的时候才知道并检查谈们的元素约束类型。

》优先考虑泛型

》38:检查参数的有效性

》39:必要时进行保护性拷贝。

》40:谨慎设计方法签名。

● 谨慎的选择方法的名字。

● 不要过于追求过于简便的方法。

● 避免过长的参数列表(4个或更少)

减少参数的方法:

分解成多个方法

创建辅助类

采用builder模式。

● 对于参数类型,要优先使用接口而不是类。

》41:慎用重载

》42:慎用可变参数

》43:返回0长度的数组或者集合,而不是返回null。

》44:为所有导出的API元素编写文档注释。

   第八章 通用程序设计

》将局部变量的作用域最小化。

● 最有利的方法就是在第一次使用它的地方声明。

》for-each优先于for循环

》了解和使用类库

》如果需要精确的答案,避免使用double与float。

Effective Java 读书笔记的更多相关文章

  1. Effective Java读书笔记完结啦

    Effective Java是一本经典的书, 很实用的Java进阶读物, 提供了各个方面的best practices. 最近终于做完了Effective Java的读书笔记, 发布出来与大家共享. ...

  2. Effective java读书笔记

    2015年进步很小,看的书也不是很多,感觉自己都要废了,2016是沉淀的一年,在这一年中要不断学习.看书,努力提升自己 计在16年要看12本书,主要涉及java基础.Spring研究.java并发.J ...

  3. Effective Java 读书笔记(一):使用静态工厂方法代替构造器

    这是Effective Java第2章提出的第一条建议: 考虑用静态工厂方法代替构造器 此处的静态工厂方法并不是设计模式,主要指static修饰的静态方法,关于static的说明可以参考之前的博文&l ...

  4. Effective Java 读书笔记之九 并发

    一.访问共享的可变数据时要同步 1.synchronized关键字既然保证访问的可见性也能保证原子性.而volatile修饰符只能保证变量的线程可见性. 2.增量操作符等不是原子性,多线程操作时可能导 ...

  5. Effective Java 读书笔记之七 通用程序设计

    一.将局部变量的作用域最小化 1.在第一次使用变量的地方声明 2.几乎每个变量的声明都应该包含一个初始化表达式:try-catch语句是一个例外 3.使方法小而集中是一个好的策略 二.for-each ...

  6. Effective Java 读书笔记之一 创建和销毁对象

    一.考虑用静态工厂方法代替构造器 这里的静态工厂方法是指类中使用public static 修饰的方法,和设计模式的工厂方法模式没有任何关系.相对于使用共有的构造器来创建对象,静态工厂方法有几大优势: ...

  7. [Effective Java读书笔记] 第二章 创建和销毁对象(1~7)

    我的技术博客经常被流氓网站恶意爬取转载.请移步原文:http://www.cnblogs.com/hamhog/p/3537576.html,享受整齐的排版.有效的链接.正确的代码缩进.更好的阅读体验 ...

  8. Effective Java读书笔记——第三章 对于全部对象都通用的方法

    第8条:覆盖equals时请遵守通用的约定 设计Object类的目的就是用来覆盖的,它全部的非final方法都是用来被覆盖的(equals.hashcode.clone.finalize)都有通用约定 ...

  9. Effective Java 读书笔记(五):Lambda和Stream

    1 Lamdba优于匿名内部类 (1)DEMO1 匿名内部类:过时 Collections.sort(words, new Comparator<String>() { public in ...

  10. Effective Java 读书笔记(四):泛型

    1 不要使用原始类型 (1)术语 术语 例子 参数化类型(Parameterized type) List<String> 实际类型参数(Actual type parameter) St ...

随机推荐

  1. 总结的一些微信API接口

    本文给大家介绍的是个人总结的一些微信API接口,包括微信支付.微信红包.微信卡券.微信小店等,十分的全面,有需要的小伙伴可以参考下. 1. [代码]index.php <?php include ...

  2. Linux下Oracle重启问题

    一.切换成oracle用户 $ su - oracle 注意:不要写成“su oracle ”不然是没办法使用下面的命令的. 如下所示:将会报:command not found的错误 二.使用命令 ...

  3. css通用小笔记02——浮动、清除(三个例子)

    css中通常会用到浮动与清除,也是一个必须掌握的知识点,概念性的东西不多说,下面举几个例子,来说明它的用法:1.文字环绕效果  2.多个div并排显示 3.清除浮动(默认显示) 一.文字环绕效果: h ...

  4. clang 搭建和编译boost 和zero ICE库 (Ubuntu10 64)

    相关介绍资料如下: Boost编译http://sourceforge.net/projects/boost/files/boost/1.55.0/boost_1_55_0.tar.gz/downlo ...

  5. C/C++构建系统 -工具汇总

    关于构建系统可以先参考百科 http://en.wikipedia.org/wiki/List_of_build_automation_software http://www.drdobbs.com/ ...

  6. Android 查看手机中所有进程

    真机测试的时候发现DDMS对进程的显示很不给力,一些进程管理工具又不显示包名. 所以就自己写了一个小程序,查看自己手机中的进程,显示当前时间和进程的包名: 程序运行截图: 布局: <Linear ...

  7. 详细对比IB开发与纯手码开发的优劣。

    1.IB是什么? Interface Builder 是一种通过图形化界面搭建UI的方式,并把窗口.菜单栏以及窗口上的各种控件的对象都“冻结”在了一个 NIB文档里:程序运行时,这些对象将会“苏醒”. ...

  8. leetcode 第188题,我的解法,Best Time to Buy and Sell Stock IV

    <span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255) ...

  9. android调试工具DDMS的使用详解

    具体可见http://developer.android.com/tools/debugging/ddms.html. DDMS为IDE和emultor.真正的android设备架起来了一座桥梁.开发 ...

  10. Java中的查找算法之顺序查找(Sequential Search)

    Java中的查找算法之顺序查找(Sequential Search) 神话丿小王子的博客主页 a) 原理:顺序查找就是按顺序从头到尾依次往下查找,找到数据,则提前结束查找,找不到便一直查找下去,直到数 ...