首先设计Book类并用Map实现分类归档,再通过Collections.sort()与Comparator进行多字段排序,结合Stream API实现高效查询,最终构建一个可扩展的图书检索系统。

在Java开发中,图书分类检索程序是一个典型的集合与排序操作的应用场景。通过这个小项目,可以深入理解List、Map等集合类的使用,掌握自定义对象排序的方法,提升对数据组织与查询逻辑的把控能力。
构建图书类与分类结构
首先要设计一个Book类,包含书名、作者、分类、出版年份等属性,并重写toString()方法方便输出查看。
为了实现分类管理,可以使用Map
示例代码片段:
立即学习“Java免费学习笔记(深入)”;
class Book {
private String title;
private String author;
private String category;
private int year;
// 构造方法、getter/setter省略
@Override
public String toString() {
return "《" + title + "》 by " + author + " (" + year + ") [" + category + "]";
}
}
使用集合存储与分类归档
创建一个HashMap用于存放不同分类的图书列表。遍历图书数据时,判断该分类是否已存在,若不存在则初始化一个ArrayList。
关键操作包括:
- 检查Map中是否存在指定分类的key
- 若无,则put(key, new ArrayList())
- 获取对应List并添加当前图书对象
这样就完成了图书按类别的自动归档,后续可直接通过分类名获取所有相关书籍。
实现多种排序检索方式
Java中的Collections.sort()和Comparator接口是实现灵活排序的核心工具。可以根据需求对图书进行多种排序:
- 按出版年份升序或降序排列
- 按书名字典顺序排序
- 按作者姓名排序
例如,按年份排序可写成:
Listbooks = bookMap.get("编程"); books.sort(Comparator.comparing(Book::getYear).reversed());
支持链式调用,还能组合多个条件排序,比如先按分类再按年份。
提供简单查询接口
可以封装几个方法供外部调用,如searchByCategory(String cat)返回某类所有图书,searchByAuthor(String author)遍历所有分类查找指定作者的作品。
结合Stream API能让查询更简洁:
Listresult = allBooks.stream() .filter(b -> b.getAuthor().contains("张")) .sorted(Comparator.comparing(Book::getTitle)) .collect(Collectors.toList());
这提升了代码可读性和功能性。
基本上就这些。掌握集合组织、分类归档与多维度排序,就能构建出一个实用的图书检索系统。这类练习对理解Java基础非常有帮助。不复杂但容易忽略细节,比如空指针处理或可变集合暴露问题,实际编码中要注意封装性。










