图书借阅系统核心是对象建模:Book、Reader、BorrowRecord、LibrarySystem四类各司其职;用组合替代继承,状态私有并封装行为(如tryBorrow/returnBook),内存集合支撑初期演示,逻辑清晰后再替换持久化。
用Java做图书借阅系统,核心不是堆代码,而是想清楚“谁在什么场景下做什么事”——对象建模就是把现实里的借书、还书、读者、图书这些角色和行为,准确翻译成类、属性和方法。
先别急着写类,拿纸笔画一画:图书馆里最不能少的是图书(Book)、读者(Reader)、借阅记录(BorrowRecord),还有统筹管理的图书管理系统(LibrarySystem)。每个类只管自己该管的事:
setAvailable(false)这类配合方法别一上来就让Reader继承Person、Book继

private List borrowHistory; ——一个读者有多个借阅记录Map bookCatalog; 和List registeredReaders; ——系统掌握所有资源Reader reader;和Book book;引用——记录天然关联双方这样改一次状态(比如还书),只要在LibrarySystem里调用record.setReturnTime(new Date()) + book.setAvailable(true),数据一致性自然保障。
图书的“可借”状态不能随便被外部设为true/false。要让Book自己控制状态流转:
isAvailable设为privateboolean tryBorrow():内部判断是否可借,可借则设为false并返回true;否则返回falsevoid returnBook():只在确认已借出时才设为true,避免重复还书出错同样,Reader的借书上限检查也封装在canBorrowMore()里,而不是让LibrarySystem去读它的count字段再比较——行为和数据绑在一起,模型才健壮。
不用一上来集成MySQL或Hibernate。先用内存集合模拟数据落地:
等模型跑通、业务逻辑清晰了,再把ArrayList换成JDBC或MyBatis,替换成本极低——因为上层只依赖抽象行为,不依赖存储细节。