[Effective Java 3rd Edition](https://www.amazon.co.jp/Effective-Java-%E7%AC%AC3%E7%89%88-%E3%], qui est un livre indispensable pour les utilisateurs Java intermédiaires et supérieurs. 82% B8% E3% 83% A7% E3% 82% B7% E3% 83% A5% E3% 82% A2% E3% 83% BB% E3% 83% 96% E3% 83% AD% E3% 83% 83% E3% 82% AF-ebook / dp / B07RHX1K53) a une version Kindle, donc je vais le résumer. "Chapitre 1 Introduction" est principalement une explication des termes, donc je vais l'ignorer.
Précédent: Aucun Suivant: Méthodes efficaces de Java 3rd Edition Chapitre 3 communes à tous les objets
Boolean.valueOf (boolean b).[Good]exemple de méthode de fabrique statique
public static Boolean valueOf(boolean b) {
  return b ? Boolean.True : Boolean.False
}
[Good]Exemple de classe Builder
public class NutritionFacts {
    private final int savingSize;
    private final int savings;
    private final int calories;
    private final int fat;
    private final int sodium;
    private final int carbohydrate;
    public static class Builder {
        //Obligatoire
        private final int savingSize;
        private final int savings;
        //Valeur par défaut facultative
        private int calories = 0;
        private int fat = 0;
        private int sodium = 0;
        private int carbohydrate = 0;
        public Builder(int savingSize, int savings) {
            this.savingSize = savingSize;
            this.savings = savings;
        }
        public Builder calories(int val) {
            calories = val;
            return this;
        }
        public Builder fat(int val) {
            fat = val;
            return this;
        }
        public Builder sodium(int val) {
            sodium = val;
            return this;
        }
        public Builder carbohydrate(int val) {
            carbohydrate = val;
            return this;
        }
        public NutritionFacts build() {
            return new NutritionFacts(this);
        }
    }
    private NutritionFacts(Builder builder) {
        savingSize = builder.savingSize;
        savings = builder.savings;
        calories = builder.calories;
        fat = builder.fat;
        sodium = builder.sodium;
        carbohydrate = builder.carbohydrate;
    }
}
@ BuilderExemple d'utilisation de lombok
import lombok.Builder;
import lombok.NonNull;
@Builder
public class LombokNutritionFacts {
    //Obligatoire
    @NonNull
    private final Integer savingSize;
    @NonNull
    private final Integer savings;
    //Définition de la valeur par défaut
    @Builder.Default
    private final Integer calories = 0;
    @Builder.Default
    private final Integer fat = 0;
    @Builder.Default
    private final Integer sodium = 0;
    @Builder.Default
    private final Integer carbohydrate = 0;
}
[Good]Classe singleton utilisant le type enum
//Classe singleton utilisant le type enum
public enum Elvis {
    INSTANCE;
    public void leaveTheBilding() {
        System.out.println("Hello Elvis!");
    }
}
//Exemple d'appel
public class Main {
    public static void main(String[] args){
        Elvis elvis = Elvis.INSTANCE;
        elvis.leaveTheBilding();
    }
}
[Good]
//Classes d'utilité qui ne peuvent pas être instanciées
public class UtilityClass {
    //Créer un constructeur privé afin qu'il ne puisse pas être instancié
    private UtilityClass() {
        throw new AssertionError();  //Lancer si appelé en classe
    }
    //Omis ci-dessous
}
[Bad]
//Mauvaise utilisation des utilitaires statiques. Il manque de flexibilité et ne peut pas être testé.
public class SpellCheckerStatic {
    private static final Lexicon dictionary = new MyDictionary();
    private SpellCheckerStatic() {
    }
    public static boolean isValid(String word) {
        //réduction
    }
    public static List<String> suggestions(String type) {
        //réduction
    }
}
[Good]
//L'injection de dépendance est flexible et testable
public class SpellChecker {
    private final Lexicon dictionary;
    public SpellChecker(Lexicon dictionary) {
        this.dictionary = Objects.requireNonNull(dictionary);
    }
    public boolean isValid(String word) {
        //réduction
    }
    public List<String> suggestions(String type) {
        //réduction
    }
}
//Cela crée des objets inutiles, donc
String s = new String("bikini");
//Devrait faire ça
String s = "bikini";
public class RomanNumerals {
    private static final Pattern ROMAN = Pattern.compile(
            "^(?=.)M*(C[MD]|D?C{0,3})" +
                    "(X[CL]|L?X{0,3})(I[XV]|V?I{0,3})$");
    //[Bon exemple] Version améliorée qui réutilise des objets
    static boolean isRomanNumerial(String s) {
        return ROMAN.matcher(s).matches();
    }
    //[Pas un bon exemple] Les performances sont médiocres en cas d'utilisation répétée
    static boolean isRomanNumerialBad(String s) {
        return s.matches("^(?=.)M*(C[MD]|D?C{0,3})" +
                "(X[CL]|L?X{0,3})(I[XV]|V?I{0,3})$");
    }
}
--Définissez null pour les références qui ne sont plus utilisées.
public class Stack {
    private Object[] elements;
    private int size = 0;
    private static final int DEFAULT_INITIAL_CAPACITY = 16;
    public Stack() {
        this.elements = new Object[DEFAULT_INITIAL_CAPACITY];
    }
    public void push(Object e) {
        ensureCapacity();
        elements[size++] = e;
    }
    public Object pop() {
        if (size == 0)
            throw new EmptyStackException();
        Object result = elements[--size];
        elements[size] = null;  //■ Supprimer les références obsolètes ■
        return result;
    }
    //Si vous devez l'agrandir, doublez-le. Sécurisez au moins une capacité.
    private void ensureCapacity() {
        if (elements.length == size) {
            elements = Arrays.copyOf(elements, 2 * size + 1);
        }
    }
}
comme son nom l'indique.
Recommended Posts