前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。
一、用静态工厂方法代替构造器
用静态工厂的优点 :
1. 方法有名字,更好理解。
2.不必每次调用的时候都创建一个新对象。
3.可以返回原类型的子类型对象,这样在选择返回类型的时候有了更大的灵活性。
4。在创建参数化类型的实例的时候,使代码更简洁。
静态工厂的缺点:
1.本类如果不含有公有或是受保护的构造器,就不能被子类化。
2.与其它的静态方法实际上没有任何区别。
二、遇到多个构造参数用构建器
1.实现方式:静态成员类(静态内部类)。 public static class Builder { ... }
客户端代码可以简写为:Student stu = new Student.Builder (20 , 10).birthday("1996-10-13").grade("大二").build();
这样当大多数参数都是可选的时候,与使用传统的不断重载的构造器模式相比,使用 builder 模式的客户端代码更易于阅读和理解。构建器也比 java beans 更安全。
三、用私有构造或者枚举强化 Singleton属性
实现1:公有 + 静态 + final ,如: public static final INSTANCE;
实现2:privatestatic final XxxxINSTANCE = new Xxxx( ) ;
public staticXxxxgetInstance ( ) {returnINSTANCE; }
实现3:单个元素的枚举类型。
四、通过私有构造器强化不可实例化
比如:工具类中的方法都应该是静态的,工具类不应当被实例化。
五、避免创建不必要的对象
1. 能直接赋值就不要new , 如:String str = new String("123" ) ,应当写为 String str = "123" ;
2. 高频率使用的代码可以考虑抽离为一个方法,该方法可以考虑定义为静态方法。
3.优先使用基本类型,而不是包装类,当心无意识的自动装箱,会生成不少多余的对象。
六、消除过期对象的引用
1. 所谓的过期引用是指永远也不会再被解除的引用 。比如定义了一个数组,但是其中的部分元素是确定不会被使用的。这种情况视为对象引用 已经过期,就应该清空这些元素,清除这些引用。这样如果以后又被错误的引用 就会立即抛出 NollPointException 。
2. 消除过期引用可帮助防止内存泄露,内存泄露的常见来源是缓存,有时候会把对象的引用 放入到缓存当中,并且长时间遗忘了它,这时就应该考虑缓存中的项是否全都依旧有意义。所以缓存应该不时的清除掉已经无用的项。清除工作可由后台一个线程来完成。
3. 监听器和其它回调也有可能导致内存泄露。如果你实现了一个API, 客户端在API中注册回调,却一直没有显示的取消注册,那么除非你采取某些动作,否则它们就会不断聚集。确保回调立即被当作垃圾回收的最佳方法是保存它们的弱引用,,例如只将它们 保存为WeakHashMap中的键。
七、避免使用最终方法
1. 最终方法就是 finalize( ) ,垃圾回收方法。原因是不能保证会及时回收,甚至不能保证会被回收(如果未被捕获的异常在终结过程中被抛出来,那么这种异常可能会被忽略)。并且使用终结方法会有严重的性能损失。因此,不应该依赖终结方法来更新重要的持久状态。
2. 应该使用显示的终止方法,通常与 try - finally 结合使用,以确保及时终止。比如字节流、字符流、数据库连接等就应该使用显示的 close 方法。