less, but is more.

创建和销毁对象

  • 静态工厂方法代替构造器
  • 优点
  • 有名称
  • 重用对象,考虑Flyweight模式
  • 可返回子类型,多态
  • 参数化类型实例,代码更简洁。右侧类型推导 Java7支持,Java优化
  • 缺点
  • 如果不含public或protected构造器,不能子类化
  • 是个静态方法,doc中不会明确标识其起到了构造器作用

避免创建不必要对象

  • 不可变对象,尽量重用而不是创建
  • 优先使用基本类型,而不是装箱类型
  • 衡量重用与new,小对象创建和回收毕竟是廉价的

消除过期的对象引用

  • 过期对象,null值清空,如数组元素
  • 缓存、监听器/回调时,尽量使用弱引用,如WeakHashMap,LinkedHashMap的removeEldestEntry

使可变性最小

不可变类,实例不可修改,创建时初始化,lifetime内固定不变,如String类,原则:

  • 不提供修改对象状态的方法
  • 类不可扩展,final
  • 所有的域final
  • 所有的域私有
  • 任何可变组件均互斥访问

泛型

  • 不要在新代码中使用原生态类型

    • 原生态类型,失掉了泛型在安全性和表述性方面的所有优势。之所以Java支持原生态类型,也是保持对已有Java代码的兼容性(移植兼容性)
  • 可以使用@SuppressWarnings("unchecked")消除非受检警告
  • 泛型优先使用List而不是数组,数组是协变的
  • 优先考虑泛型方法
  • 利用有限制通配符提升API灵活性
  • PECS(producer-extends,consumer-super)读 ?extends,写 ?super
  • 所有的comparable和comparator都是消费者

用标记接口定义类型

  • 标记接口(marker interface)无方法接口声明
  • 标记接口,只应用给类和接口,可以用接口作为相关方法的参数类型,优点:
  • 标记接口可以在编译时捕捉异常
  • 更加精确的锁定
  • 标记注解,单标记应用于任何程序元素时,考虑用此,优点:
  • 可以添加一个或多个注解类型元素
  • 支持注解作为编程元素之一的框架中具有一致性

检查参数有效性

编写方法或构造器时,应该考虑下参数有哪些限制,显式的检查来实施这些限制。

慎用重载

  • 重载方法(overloaded method),重写/覆盖方法(overridden method)
  • 参数数目相同时,尽量避免重载方法,尤其是参数类型有着关系(如继承)

返回零长度的数组或集合,而不是null

需要精确答案时,避免使用float和double

数值超过18位数字时,可以考虑BigDecimal

字符串连接的性能

  • 当两个字符串通过+连接在一起时,他们的内容都要被拷贝,使用StringBuilder代替String,通过append方法进行操作。
  • StringBuilder预先定义足够容量时,要比默认大小的StringBuilder快。【深有体会..】

接口优先于反射机制

  • 反射缺点:

    • 失去编译时的类型检查
    • 反射访问的代码笨拙而冗长
    • 性能损失(2~50倍,不确定)
  • System.exit会终止整个VM....

可恢复情况使用受检异常,编程错误使用运行时异常

三种可抛出(throwable)结构:

  • 受检的异常(checked exception)
  • 运行时异常(runtime exception)
  • 错误(error)

如果期望调用者能够适当的恢复,使用受检的异常。通过抛出每个受检异常,强迫调用者处理该异常,或者继续传播。
运行时异常和错误,不需要也不应该被捕获,毕竟往往是不可回复的情形。

慎用延迟初始化及双重检查

  • 实例域,使用双重检查(double-check)需要配合volatile
  • 静态域,使用lazy initialization holder class,(静态内部类=..=)
  • 可重复初始化实例域,使用单重检查模式

EffectiveJava读书笔记的更多相关文章

  1. <EffectiveJava>读书笔记--02泛型数组

    1, java中可以申明泛型类型的数组引用; 2, 但是不能实例化一个泛型数组对象; 3, 针对第二点, 可以曲线救国, 实例化一个Object数组, 再进行类型强转; 见代码如下: public c ...

  2. <EffectiveJava>读书笔记--01继承的使用注意

    1, 父类的构造器方法中不能调用能够被子类重写的方法. 分析: 当初始化一个子类时, 首先要初始化父类, 即调用父类的构造方法; 如果父类的构造方法中调用了可被重写的其它方法, 那么此时调用的其实是该 ...

  3. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

  4. 读书笔记--SQL必知必会18--视图

    读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...

  5. 《C#本质论》读书笔记(18)多线程处理

    .NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...

  6. C#温故知新:《C#图解教程》读书笔记系列

    一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...

  7. C#刨根究底:《你必须知道的.NET》读书笔记系列

    一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...

  8. Web高级征程:《大型网站技术架构》读书笔记系列

    一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...

  9. LOMA280保险原理读书笔记

    LOMA是国际金融保险管理学院(Life Office Management Association)的英文简称.国际金融保险管理学院是一个保险和金融服务机构的国际组织,它的创建目的是为了促进信息交流 ...

随机推荐

  1. CSS层叠样式表的解释

    css:    在标签上设置style属性css注释:     /*z注释内容*/css样式的编写位置:    1.在标签的的style属性里    2.在head里面,style标签中写样式     ...

  2. 命令行编译 WPF

    在开发调试代码 WPF 时,经常需要在修改完成代码后,点击 Rebuild,然后到指定文件夹下点击打开对应的 .exe 验证程序是否正确, 可以通过以下命名实现修改程序后,点击一个 .bat 文件,直 ...

  3. Hadoop2.5.2集群部署(完全分布式)

    环境介绍 硬件环境 CPU 4 MEM 4G 磁盘 60G  软件环境 OS:centos6.5版本 64位 Hadoop:hadoop2.5.2 64位 JDK: JDK 1.8.0_91 主机配置 ...

  4. anaconda常用的命令

    常用操作命令: 一.环境操作 1.查看环境管理的全部命令帮助: conda env -h 2.查看当前系统下的环境: conda info -e 3.创建环境: conda create env_na ...

  5. truffle的调用nodeJs的问题

    Truffle3.0集成NodeJS并完全跑通(附详细实例,可能的错误) 升级到Truffle3.0 如果之前安装的是Truffle2.0版本,需要主动升级到Truffle3.0,两者的语法变化有点大 ...

  6. 官方文档 恢复备份指南四 Starting and Interacting with the RMAN Client

    本章讲: Starting and Exiting RMAN Specifying the Location of RMAN Output                                ...

  7. STL应用——hdu1702(队列+堆栈)

    水题 练习一下堆栈和队列的使用 #include <iostream> #include <cstdio> #include <algorithm> #includ ...

  8. lintcode-93-平衡二叉树

    93-平衡二叉树 给定一个二叉树,确定它是高度平衡的.对于这个问题,一棵高度平衡的二叉树的定义是:一棵二叉树中每个节点的两个子树的深度相差不会超过1. 您在真实的面试中是否遇到过这个题? Yes 样例 ...

  9. [剑指Offer] 36.两个链表的第一个公共结点

    题目描述 输入两个链表,找出它们的第一个公共结点. [思路]找出两个链表的长度,然后让长的走两个链表的长度差,然后再一起走(因为两个链表用公共的尾部). /* struct ListNode { in ...

  10. 集群hadoop ubuntu版

    搭建ubuntu版hadoop集群 用到的工具:VMware.hadoop-2.7.2.tar.jdk-8u65-linux-x64.tar.ubuntu-16.04-desktop-amd64.is ...