php中文网

编写可重用 Java 函数的通用原则和准则

php中文网

可重用 java 函数的原则和准则包括:单一职责原则:每个函数只负责一个明确的任务。dry 原则:避免重复相似的逻辑,将共享逻辑提取到单独的函数或类中。高内聚,低耦合:将相关代码组件分组,降低依赖性。接口和抽象类:定义函数的公共契约,而无需指定具体实现。使用 javadoc 注释函数的输入、输出、异常和用途。

编写可重用 Java 函数的原则和准则

编写可重用的代码是 Java 开发中的关键实践,它可以增强代码的可维护性、可读性和可扩展性。本文将讨论编写可重用 Java 函数的通用原则和准则,并提供实际案例来演示这些原则的应用。

单一职责原则

每​​个函数都应该只执行一个、定义明确的任务。这有助于降低耦合度,并使函数更容易理解和测试。

示例:

立即学习“Java免费学习笔记(深入)”;

public String formatPhoneNumber(String phoneNumber) {
  // 规范化电话号码,移除所有特殊字符
  String normalizedPhoneNumber = phoneNumber.replaceAll("[^0-9]", "");
  // 根据给定的格式格式化电话号码
  return String.format("(%s) %s-%s", normalizedPhoneNumber.substring(0, 3), normalizedPhoneNumber.substring(3, 6), normalizedPhoneNumber.substring(6));
}

DRY 原则(不要重复自己)

避免在代码中重复相同或相似的逻辑。提取共享逻辑到单独的函数或类中。

示例:

立即学习“Java免费学习笔记(深入)”;

// 提取在多个函数中使用的验证电子邮件地址的逻辑
public boolean isValidEmailAddress(String emailAddress) {
  return emailAddress.matches("^[\w-_.+]*@[\w-_.+]*\.[\w-_.+]*$");
}

高内聚,低耦合

将相关的代码组件组合到模块或子系统中,以降低相互依赖性。这使函数更易于理解、更改和维护。

示例:

立即学习“Java免费学习笔记(深入)”;

// 将与用户验证相关的函数分组到一个模块中
public class UserValidationModule {

  public static boolean isValidUsername(String username) {
    // 验证用户名是否有效
  }

  public static boolean isValidPassword(String password) {
    // 验证密码是否有效
  }
}

接口和抽象类

使用接口和抽象类定义函数的公共契约,而无需指定具体实现。这使您可以在不破坏现有客户的情况下交换实现。

示例:

立即学习“Java免费学习笔记(深入)”;

// 定义一个接口来表示排序算法
public interface SortingAlgorithm {
  int[] sort(int[] numbers);
}

// 提供具体实现的具体类
public class BubbleSort implements SortingAlgorithm {
  @Override
  public int[] sort(int[] numbers) {
    // 实现冒泡排序算法
  }
}

使用 JavaDoc

使用 JavaDoc 注释来记录函数的输入、输出、异常和用途。这使开发人员可以更轻松地理解和使用库或第三方代码。

示例:

立即学习“Java免费学习笔记(深入)”;

/**
 * 格式化电话号码
 *
 * @param phoneNumber 电话号码
 * @return 格式化的电话号码
 */
public String formatPhoneNumber(String phoneNumber) {
  // ...
}

实战案例

使用上述原则和准则,让我们考虑一个可重用函数的实际案例,用于将数字列表转换为字符串列表:

import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class NumberToStringConverter {

  public static List<String> convertNumbersToStrings(List<Integer> numbers) {
    return numbers.stream()
        .map(Object::toString)
        .collect(Collectors.toList());
  }
}

此函数遵循单一职责原则,因为它只负责将数字列表转换为字符串列表。它还避免了重复的代码,因为它使用了 Java 8 的流 API 来执行转换。该函数内聚度高,与任何特定集合实现无关,并且使用 JavaDoc 记录良好。

以上就是编写可重用 Java 函数的通用原则和准则的详细内容,更多请关注php中文网其它相关文章!