代码中使用 Iterable<T> 作为方法参数的解释
/**
* 根据课程 id 集合查询课程简单信息
* @param ids id 集合
* @return 课程简单信息的列表
*/
@GetMapping("/courses/simpleInfo/list")
List<CourseSimpleInfoDTO> getSimpleInfoList(@RequestParam("ids") Iterable<Long> ids);
一、代码解释:
@GetMapping("/courses/simpleInfo/list")
:这是一个 Spring 框架的注解,将该方法映射到/courses/simpleInfo/list
的 GET 请求路径上。List<CourseSimpleInfoDTO> getSimpleInfoList(@RequestParam("ids") Iterable<Long> ids)
:定义了一个名为getSimpleInfoList
的方法,它接收一个名为ids
的请求参数,并将该参数映射到Iterable<Long>
类型的ids
变量上,最终返回一个CourseSimpleInfoDTO
类型的列表。
二、使用 Iterable
的原因及好处:
-
抽象性和通用性:
Iterable
是 Java 集合框架中的一个接口,它是集合类的最基本接口之一,实现了Iterable
接口的类都可以使用forEach
方法进行迭代。常见的集合类,如List
、Set
和Queue
都实现了Iterable
接口。- 使用
Iterable<Long>
作为参数类型,使方法具有更高的抽象性和通用性。该方法可以接受任何实现了Iterable
接口的集合类,如ArrayList<Long>
、LinkedList<Long>
、HashSet<Long>
等,而不局限于某种特定的集合类型。这样,在调用该方法时,你可以灵活地使用不同的集合类来存储课程id
,提高了代码的灵活性和可扩展性。
-
迭代操作的便利性:
- 由于
Iterable
接口提供了forEach
方法,在方法内部可以方便地对传入的ids
集合进行迭代操作,而无需关心其具体实现类型。例如:for (Long id : ids) { // 对 id 进行处理 }
或者使用 Java 8 的 Lambda 表达式和流处理:
-
ids.forEach(id -> { // 对 id 进行处理 });
这使得代码更加简洁和易于阅读,并且可以利用 Java 8 及以上版本的新特性。
- 由于
-
能传入单个id
当你传递单个 id
时,Spring 会尝试将这个 id
转换为 Long
类型,并将其视为一个包含一个元素的可迭代集合。例如,如果你发送一个 GET
请求:/courses/simpleInfo/list?ids=123
,Spring 会将 123
转换为 Long
类型,并将其存储在 ids
这个可迭代集合中,其内部可以看作是包含一个元素的集合,类似于 Arrays.asList(123L)
。例如:
List<CourseSimpleInfoDTO> courseSimpleInfoDTOList = courseClient.getSimpleInfoList(Collections.singleton(learningLesson.getCourseId()));
解释:
Collections
类:
Collections
是 Java 中的一个实用工具类,它提供了许多静态方法,用于操作和处理集合对象。
singleton
方法:
Collections.singleton()
是Collections
类中的一个静态方法。- 该方法接收一个元素作为参数,并返回一个不可变的
Set
集合,该集合中只包含这个元素。
整体解释:
Collections.singleton(learningLesson.getCourseId())
的作用是将learningLesson.getCourseId()
的结果包装成一个只包含一个元素的不可变Set
集合。- 这样做的目的可能是为了将单个
id
作为集合传递给courseClient.getSimpleInfoList
方法,因为getSimpleInfoList
方法接收的参数是@RequestParam("ids") Iterable<Long> ids
,即一个Long
类型元素的可迭代集合,而Set
是Iterable
的子接口。通过使用Collections.singleton()
,将单个id
包装成集合,满足了方法参数的要求。
例如,如果 learningLesson.getCourseId()
返回的结果是 123L
,那么 Collections.singleton(learningLesson.getCourseId())
将生成一个包含 123L
的 Set<Long>
,其大小为 1,且这个 Set
是不可变的,即不能添加或删除元素。
需要注意的是,由于 Set
是不可变的,后续无法向这个集合中添加其他 id
,如果需要传递多个 id
,应该使用其他的集合创建方法,如 new HashSet<>()
或 Arrays.asList()
等,根据具体情况添加多个元素。
这种方式在需要将单个元素作为集合传递给接收集合参数的方法时非常有用,可以保证代码的通用性和类型安全。同时,使用 Collections.singleton()
可以避免创建不必要的大型集合,对于只包含一个元素的情况,可以提高性能和资源利用率。