Effective Java Chapter 1 - how to create a Object

Effective Java 读书笔记

Item 1:考虑用静态工厂方法代替构造器

  • 顾名思义就是使用静态方法来构造对象
优点 1:静态工厂方法与其它构造器不同的优点在于他们有名称
  • 这样使用的好处是调用者能够通过名字来判别应该调用哪个构造器,比较通俗的例子如下:
public class Person {   
    private String gender;

    private Person(String gender) {
        this.gender = gender;
    }

    private static Person FEMALE = new Person("female");
    private static Person MALE = new Person("male");

    public static Person getAFemale() {
        return FEMALE;
    }

    public static Person getAMale() {
        return MALE;
    }

    .....
}

public class Main {
    public static void main(String[] args) {
        Person male = Person.getAMale();
        Person female = Person.getAFemale();
        ......
    }
}
优点2:静态工厂方法使得在获取一个类的实例化的时候,不必重新创建一个新的对象,降低了消耗,提升了性能
  • 在高并发的情况下,如果一个对象不可变,那就应该考虑使用静态工厂方法来代替构造器,这样,就不用每次请求都创建新的对象。最好的例子就是Boolean.ValueOf()
{
    ...
    private static Boolean Boolean.TRUE = new Boolean(true);

    private static Boolean Boolean.FALSE = new Boolean(false);

    public static Boolean valueOf(boolean b) {
        return b ? Boolean.TRUE : Boolean.FAlSE;
    }
    ...
}
优点3:应为构造器本身只能返回类对象本身的限制,静态工厂方法能够返回子类对象,最好的应用就是Service provider framework。Service provider framework能够成立的基础点就是静态工厂模式
  • 稍后附上链接
优点4:结合泛型,当类的构造器的参数类型很长的时候,静态工厂方法能够简化代码,如下所示:
  • 最常见的举例如下:
public class Main() {
    public static void main(String[] args) {
        //传统构造方法
        HashMap<String, List<String>> mapWithTraditionalConstruct = new HashMap<String, List<String>>();
        //静态工厂构造方法
        HashMap<String, List<String>> mapWithNewConstruct = Maps.newHashMap();
    }
}

//内部实现如下
public final class Maps {
  private Maps() {}
  ...
  public static <K, V> HashMap<K, V> newHashMap() {
      return new HashMap<K, V>();
      }
  ...
}

Item 2:当构造器需要多个参数的时候,考虑用Builder模式创建对象

  • 假设有这样一种场景,使用effectiveJava中的例子,当类拥有多个属性,并且对象需要的属性根据不同的场景会不同,通常方法是使用重叠构造器模式
public Class Demo1 {
    private String param1;
    private String param2;
    private String param3;

    public Demo1(String param1) {
        this.param1 = param1;
    }

    public Demo2(Strig param1, String param2) {
        this.param1 = param1;
        this.param2 = param2;
    }

    public Demo3(String param2, String param3) {
        this.param2 = param2;
        this.param3 = param3;
    }

    public Demo4(String param1, String param3) {
        this.param1 = param1;
        this.param3 = param3;
    }

    public Demo5(String param1, String param2, String param3) {
        this.param1 = param1;
        this.param2 = param2;
        this.param3 = param3;
    }
}
  • 重叠式构造确实能够解决一部分问题,但是它大大的增加了代码的可读性以及coding,例如,当参数增加到了5的时候,构造函数的个数也随之增加到了C-5-5(5的组合)个。JavaBean模式能够很好的解决这一个问题:
    private String param1;
    private String param2;
    private String param3;

    public Demo1() {
    }

    public void setParam1(String param1) {
        this.param1 = param1;
    }

    public void setParam2(String param2) {
        this.param2 = param2;
    }

    public void setParam1(String param3) {
        this.param3 = param3;
    }   
  • 但是JavaBean有一个致命的缺陷:JavaBean的set方法阻止了类的不可变,这使得在多线程情况下需要耗费额外的精力来保证线程安全。builder模式孕育而生,它解决了重叠式构造器和javabean面临的两个问题,builder模式如下:
public class City() {

    private int populationSize;

    private double sexRatio;

    private BigDecimal gdp;

    private City(Builder builder) {
        this.populationSize = builder.populationSize;
        this.sexRatio = builder.sexRatio;
        this.gdp = builder.gdp;
    }

    public static class Builder {

        private int populationSize;

        private double sexRatio;

        private BigDecimal gdp;

        public Builder() {
        }

        public Builder setPopulationSize(int populationSize) {
            this.populationSize = populationSize;
            return this;
        }   

        public Builder setSexRatio(double sexRatio) {
            this.sexRatio = sexRatio;
            return this;
        }

        public Builder setGDP(BigDecimal gdp) {
            this.gdp = gdp;
            return this;
        }

        public City build() {
            return new City(this);
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《Effective Java第三版》是由Joshua Bloch所著的一本Java编程指南。这本书是基于第二版的更新版本,目的是给Java程序员提供一些最佳实践和经验,以编写高效、可维护和可靠的Java代码。 这本书共分为15个章节,每个章节都讲解了一个与Java开发有关的重要主题。比如,章节一讲述了使用静态工厂方法代替构造器的优点,章节二则介绍了如何用Builder模式来构建复杂的对象。此外,书中还提及了Java对象的等价性、覆盖equals方法和hashCode方法、避免创建不必要的对象、使用泛型、枚举、lambda表达式等等。 《Effective Java第三版》通过具体的代码示例和清晰的解释来说明每个主题的关键概念,使读者能够更好地理解和应用。此外,书中还提供了一些实用的技巧和技术,例如避免使用原始类型、尽量使用接口而非类来定义类型等。 总的来说,这本书提供了很多实用的建议和技巧,可以帮助Java开发者写出高质量的代码。无论是初学者还是有经验的开发者,都可以从中受益匪浅。无论你是打算从头开始学习Java编程,还是已经有一定经验的开发者,这本书都是值得推荐的读物。 ### 回答2: 《Effective Java 第三版》是由Joshua Bloch 所著的一本Java编程指南,是Java程序员必读的经典之作。该书共包含90个条目,涵盖了各种Java编程的最佳实践和常见问题的解决方法。 本书分为多个部分,每个部分都侧重于一个特定的主题。作者探讨了Java编程中的各种问题和挑战,并提供了解决方案和建议。这些建议包括如何选择和使用合适的数据结构和算法,如何设计高效的类和接口,如何处理异常和错误,以及如何编写可读性强的代码等等。 《Effective Java 第三版》还关注了Java编程中的性能优化和安全性问题。作者强调了遵循Java语言规范、使用标准库、防范常见安全漏洞等重要原则。此外,本书还介绍了Java 8及其后续版本的新特性和用法,如Lambda表达式、流式编程和Optional类等。 这本书的特点之一是每个条目都独立于其他条目,可以单独阅读和理解。每个条目开头都有一个简洁的总结,让读者能够快速掌握主要观点。此外,书中还有大量的示例代码和解释,帮助读者更好地理解和运用所学知识。 总的来说,《Effective Java 第三版》是一本非常实用和全面的Java编程指南。它适用于各个层次的Java程序员,无论是初学者还是有经验的开发人员,都可以从中获得宝贵的经验和知识。无论是编写高质量的代码、优化性能还是确保安全性,这本书都是一本不可或缺的参考书籍。 ### 回答3: 《Effective Java 第3版(中文版)》是由 Joshua Bloch 所著的一本关于使用 Java 编程语言的指南书。该书是对 Java 语言的最佳实践的详尽描述,为中高级 Java 开发人员提供了许多实用的建议和技巧。 该书的主要内容包括Java 语言的优雅编程风格、类和接口的设计、Lambda 表达式和流的使用、泛型、异常和并发编程等方面的最佳实践。 在《Effective Java 第3版(中文版)》中,许多传统的 Java 开发中的陷阱、常见错误和不良习惯都得到了深入的剖析和解答。它不仅提供了可供开发人员参考的示例代码,还解释了为什么某种方式是有问题的,以及如何更好地进行改进。 该书的深度和广度非常适合正在努力提高 Java 编程技能的开发人员。它涵盖了多个关键领域,为读者提供了在实际项目中解决常见问题的方法和思路。 此外,《Effective Java 第3版(中文版)》还介绍了最新版本的一些特性和改进。例如,它详细说明了如何正确地使用 Java 8 中新增的 Lambda 表达式和流,以及如何充分利用 Java 9、10 和 11 中的新功能。 总之,这本书是 Java 开发人员必备的指南之一。通过深入理解和应用书中的实践建议,读者可以更加高效地编写、优化和维护 Java 代码。无论是想提升职业技能还是在项目中减少错误和问题,这本《Effective Java 第3版(中文版)》都是一本非常有帮助的参考书。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值