5.2。条件付き判断を避ける
普通
double result;
if (value <= MIN_LIMIT) {
result = MIN_LIMIT;
} else {
result = value;
}
合理化
double result = Math.max(MIN_LIMIT, value);
6.1。配列の使用を簡素化する
上限と下限が固定されたif-elseステートメントの場合、配列+ループを使用して単純化できます。
普通
public static int getGrade(double score) {
if (score >= 90.0D) {
return 1;
}
if (score >= 80.0D) {
return 2;
}
if (score >= 60.0D) {
return 3;
}
if (score >= 30.0D) {
return 4;
}
return 5;
}
合理化
private static final double[] SCORE_RANGES = new double[] {
90.0D, 80.0D, 60.0D, 30.0D};
public static int getGrade(double score) {
for (int i = 0; i < SCORE_RANGES.length; i++) {
if (score >= SCORE_RANGES[i]) {
return i + 1;
}
}
return SCORE_RANGES.length + 1;
}
考えてみてください。上記の場合の戻り値は増分であるため、配列を使用して単純化しても問題はありません。ただし、戻り値が増分でない場合は、配列を使用して単純化できますか?答えはイエスです。自分で考えて解決してください。
6.2。マップで簡素化する
マッピング関係のif-elseステートメントの場合、Mapを使用して単純化できます。さらに、このルールは、マッピング関係を単純化するswitchステートメントにも適用されます。
普通
public static String getBiologyClass(String name) {
switch (name) {
case "dog" :
return "animal";
case "cat" :
return "animal";
case "lavender" :
return "plant";
...
default :
return null;
}
}
合理化
private static final Map<String, String> BIOLOGY_CLASS_MAP
= ImmutableMap.<String, String>builder()
.put("dog", "animal")
.put("cat", "animal")
.put("lavender", "plant")
...
.build();
public static String getBiologyClass(String name) {
return BIOLOGY_CLASS_MAP.get(name);
}
6.3。コンテナクラスの使用を簡素化する
PythonやGoとは異なり、Javaは複数のオブジェクトを返すことをサポートしていません。複数のオブジェクトを返す必要がある場合は、クラスをカスタマイズするか、コンテナクラスを使用する必要があります。一般的なコンテナクラスには、ApacheのPairクラスとTripleクラスが含まれます。Pairクラスは2つのオブジェクトを返すことをサポートし、Tripleクラスは3つのオブジェクトを返すことをサポートします。
普通
@Setter
@Getter
@ToString
@AllArgsConstructor
public static class PointAndDistance {
private Point point;
private Double distance;
}
public static PointAndDistance getNearest(Point point, Point[] points) {
// 计算最近点和距离
...
// 返回最近点和距离
return new PointAndDistance(nearestPoint, nearestDistance);
}
合理化
public static Pair<Point, Double> getNearest(Point point, Point[] points) {
// 计算最近点和距离
...
// 返回最近点和距离
return ImmutablePair.of(nearestPoint, nearestDistance);
}
7.オプションを活用する
7.1。保証値が存在する
普通
Integer thisValue;
if (Objects.nonNull(value)) {
thisValue = value;
} else {
thisValue = DEFAULT_VALUE;
}
合理化
Integer thisValue = Optional.ofNullable(value).orElse(DEFAULT_VALUE);
7.2。保証値は合法です
普通
Integer thisValue;
if (Objects.nonNull(value) && value.compareTo(MAX_VALUE) <= 0) {
thisValue = value;
} else {
thisValue = MAX_VALUE;
}
合理化
Integer thisValue = Optional.ofNullable(value)
.filter(tempValue -> tempValue.compareTo(MAX_VALUE) <= 0).orElse(MAX_VALUE);
7.3。空の判断を避ける
普通
String zipcode = null;
if (Objects.nonNull(user)) {
Address address = user.getAddress();
if (Objects.nonNull(address)) {
Country country = address.getCountry();
if (Objects.nonNull(country)) {
zipcode = country.getZipcode();
}
}
}
合理化
tring zipcode = Optional.ofNullable(user).map(User::getAddress)
.map(Address::getCountry).map(Country::getZipcode).orElse(null);
8.ストリームを使用する
8.1。一致コレクションデータ
普通
boolean isFound = false;
for (UserDO user : userList) {
if (Objects.equals(user.getId(), userId)) {
isFound = true;
break;
}
}
合理化
boolean isFound = userList.stream()
.anyMatch(user -> Objects.equals(user.getId(), userId));
8.2。収集データのフィルター
普通
List<UserDO> resultList = new ArrayList<>();
for (UserDO user : userList) {
if (Boolean.TRUE.equals(user.getIsSuper())) {
resultList.add(user);
}
}
合理化
List<UserDO> resultList = userList.stream()
.filter(user -> Boolean.TRUE.equals(user.getIsSuper()))
.collect(Collectors.toList());
8.3。収集データを要約する
普通
double total = 0.0D;
for (Account account : accountList) {
total += account.getBalance();
}
合理化
double total = accountList.stream().mapToDouble(Account::getBalance).sum();
8.4。コレクションデータを変換する
普通
List<UserVO> userVOList = new ArrayList<>();
for (UserDO userDO : userDOList) {
userVOList.add(transUser(userDO));
}
合理化
List<UserVO> userVOList = userDOList.stream()
.map(this::transUser).collect(Collectors.toList());
8.5。コレクションデータのグループ化
普通
Map<Long, List<UserDO>> roleUserMap = new HashMap<>();
for (UserDO userDO : userDOList) {
roleUserMap.computeIfAbsent(userDO.getRoleId(), key -> new ArrayList<>())
.add(userDO);
}
合理化
Map<Long, List<UserDO>> roleUserMap = userDOList.stream()
.collect(Collectors.groupingBy(UserDO::getRoleId));
8.6。グループサマリーコレクション
普通
Map<Long, Double> roleTotalMap = new HashMap<>();
for (Account account : accountList) {
Long roleId = account.getRoleId();
Double total = Optional.ofNullable(roleTotalMap.get(roleId)).orElse(0.0D);
roleTotalMap.put(roleId, total + account.getBalance());
}
合理化
roleTotalMap = accountList.stream().collect(Collectors.groupingBy(Account::getRoleId, Collectors.summingDouble(Account::getBalance)));
8.7。範囲コレクションを生成する
普通
int[] array1 = new int[N];
for (int i = 0; i < N; i++) {
array1[i] = i + 1;
}
int[] array2 = new int[N];
array2[0] = 1;
for (int i = 1; i < N; i++) {
array2[i] = array2[i - 1] * 2;
}
合理化
int[] array1 = IntStream.rangeClosed(1, N).toArray();
int[] array2 = IntStream.iterate(1, n -> n * 2).limit(N).toArray();
9.プログラム構造を使用する
9.1。条件式を返す
条件式の判定はブール値を返し、条件式自体が結果になります
普通
public boolean isSuper(Long userId)
UserDO user = userDAO.get(userId);
if (Objects.nonNull(user) && Boolean.TRUE.equals(user.getIsSuper())) {
return true;
}
return false;
}
合理化
public boolean isSuper(Long userId)
UserDO user = userDAO.get(userId);
return Objects.nonNull(user) && Boolean.TRUE.equals(user.getIsSuper());
}