迷你图书管理系统 源代码 Java初级小项目
今天博主再给大家分享一个小项目:MiNi图书管理系统。用的是Java语言开发的,代码不多,大概260行左右吧,系统是实现图书的新增图书、删除图书、借阅图书、归还图书、查看图书等简单的功能(后附源代码)!
首先展示一下运行界面效果图:运行代码后,会在控制台显示如下界面:

然后让用户选择,如果用户不小心或者误输入了错误的数,会再次让用户进行输入。
当用户输入2后,可以查看图书,会显示已有的图书:
包括图书书名、借阅状态、借阅次数、借阅日期等信息。

当用户输入1后,可以新增图书,再次让用户输入新增的图书名字,这里博主用mybook,效果如下:

当用户输入3后,可以借阅图书。让用户再次输入借阅的图书名,如果输入的名字没在图书馆,则不可以借阅;如果在馆,且状态是已借出,也不能再次借阅;如果在馆,且状态是可借阅,则可以进行借阅。

当用户输入4后,可以归还图书。再次让用户输入归还的图书名,同理,如果图书馆找不到该名字,提示用户不是本图书馆的书,不用归还;如果找到该书的名字,且状态是可借阅的,也不能归还;如果找到该书,且状态是已借出,则可以进行图书的归还。同时,还要让用户输入归还的日期,并对归还的日期进行判断,如果日期小于借阅的日期,则提示用户归还日期必须大于借阅日期,让用户再次输入,输入成功后,则显示归还成功。

当用户输入5后,可以进行删除图书的操作。如果该馆找不到用户输入的书名,则提示用户不是本图书馆的书,不用归还;如果找到,且状态是已借出,则不能归还;如果找到该书,且书的状态是可借阅的,则可以进行删除图书的操作。

当用户输入6后,就退出系统。

源代码如下:
package cn.kgc.sg.MiTuSys;
import java.util.Scanner;
public class MiNiBookMgrSys {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
//初始化书本信息
String[] bookNames = new String[6];
int[] borrowDates = new int[6];
int[] borrowCounts = new int[6];
int[] states = new int[6];
//初始化三本书
bookNames[0] = "安徒生童话";
borrowDates[0] = 15;
borrowCounts[0] = 16;
states[0] = 0;//0:可借阅 1:已借出
bookNames[1] = "格林童话";
borrowDates[1] = 0;
borrowCounts[1] = 0;
states[1] = 1;//0:可借阅 1:已借出
bookNames[2] = "Java开发";
borrowDates[2] = 0;
borrowCounts[2] = 0;
states[2] = 0;//0:可借阅 1:已借出
int num = -1;//初始化用户输入的数字
boolean flag = true;//true:不退出系统 false:退出系统
do{
System.out.println("************欢迎使用MiNi图书管理系统**********");
System.out.println("\t\t\t\t\t1.新增图书");
System.out.println("\t\t\t\t\t2.查看图书");
System.out.println("\t\t\t\t\t3.借阅图书");
System.out.println("\t\t\t\t\t4.归还图书");
System.out.println("\t\t\t\t\t5.删除图书");
System.out.println("\t\t\t\t\t6.退出系统");
System.out.print("\n请选择:");
int choose = sc.nextInt();
while(choose<0 || choose>6){
System.out.print("输入有误,重新输入:");
choose = sc.nextInt();
}
switch(choose){
case 1:
System.out.println("************1.新增图书**********");
System.out.print("请输入新增图书的名字:");
String addBook = sc.next();
boolean isAdd = false;//false:不能添加图书 true:可以添加图书
//遍历数组,查找新增图书的位置
for(int i =1;i<bookNames.length;i++){
//数组没满,可以新增图书
if(bookNames[i] == null){
isAdd = true;
bookNames[i] = addBook;
System.out.println("新增图书成功!!!");
break;
}else{
isAdd = false;
}
}
//循环遍历输出数组内图书信息
for(int i = 0;i<bookNames.length;i++){
//如果为空,不输出
if(bookNames[i] != null){
String state = (states[i]==0)?"可借阅":"已借出"; //把借阅状态的0 1 变成易看的“可借阅 已借出”
String borrowCount = borrowCounts[i]+"次";
String borrowDate = borrowDates[i] + "日";
System.out.println((i+1)+"\t\t"+bookNames[i]+"\t\t"+state+"\t\t"+
borrowCount+"\t\t"+borrowDate);
}
}
if(!isAdd){
System.out.println("对不起,图书已满,不能新增!");
break;
}
break;
case 2:
System.out.println("2.查看图书");
System.out.println("序号"+"\t\t\t"+"书名"+"\t\t\t"+"借阅状态"+"\t\t"+"借阅次数"+
"\t\t"+"借阅日期");
//循环遍历输出数组内图书信息
for(int i = 0;i<bookNames.length;i++){
//如果为空,不输出
if(bookNames[i] != null){
String state = (states[i]==0)?"可借阅":"已借出"; //把借阅状态的0 1 变成易看的“可借阅 已借出”
String borrowCount = borrowCounts[i]+"次";
String borrowDate = borrowDates[i] + "日";
System.out.println((i+1)+"\t\t"+bookNames[i]+"\t\t"+state+"\t\t"+
borrowCount+"\t\t"+borrowDate);
}
}
break;
case 3:
System.out.println("3.借阅图书");
System.out.print("请输入您要借阅图书的名字:");
String borrowName = sc.next();
boolean isBorrow = false;//true:能借阅
for(int i = 0;i<bookNames.length;i++){
//如果可以找到书,且书的状态是可借阅,就可以借阅
if(bookNames[i] != null && bookNames[i].equals(borrowName) && states[i] == 0){
isBorrow = true;
//输入借阅日期
System.out.print("请输入借阅的日期:");
int borrowRiQi = sc.nextInt();
//判断输入的借阅日期是否合法
while(borrowRiQi < 1 || borrowRiQi > 31){
System.out.print("输入有误,重新输入:");
borrowRiQi = sc.nextInt();
}
System.out.println("借阅成功!!!");
//更改借阅日期
borrowDates[i] = borrowRiQi;
//更新借阅状态
states[i] = 1;
//更新借阅次数
borrowCounts[i]++;
break;
}else if(bookNames[i] != null && bookNames[i].equals(borrowName) && states[i] == 1){
//如果可以找到书,且书的状态是已借出,不能借阅
isBorrow = true;
System.out.println("书已经借出,不能重复借阅!");
break;
//if(bookNames[i] == null)
//if(!bookNames[i].equals(borrowName))
}/*else if(bookNames[i] == null){
isBorrow = false;
break;
}*/
}
if(!isBorrow){
//bookNames[i] == null,说明 找不到书
System.out.println("抱歉,找不到该书!!!");
break;
}
break;
case 4:
System.out.println("4.归还图书");
System.out.print("请输入您要归还图书的名字:");
String returnName = sc.next();
boolean isReturn = false;//true:能归还
for(int i = 0;i<bookNames.length;i++){
//if(!bookNames[i].equals(borrowName))
/*if(bookNames[i] == null){
//找不到书
isReturn = false;
break;
}else*/
//如果可以找到书,且书的状态是已借出,就可以归还
if(bookNames[i]!=null && bookNames[i].equals(returnName) && states[i] == 1){
isReturn = true;
//输入归还日期
System.out.print("请输入归还的日期:");
int returnRiQi = sc.nextInt();
//判断输入的归还日期是否合法
while(returnRiQi < 1 || returnRiQi > 31 || returnRiQi<borrowDates[i]){
//输入的归还日期不合法
if(returnRiQi < 1 || returnRiQi > 31){
System.out.print("输入的日期有误,重新输入:");
returnRiQi = sc.nextInt();
}else if(returnRiQi<borrowDates[i]){
System.out.print("归还日期必须大于借阅日期,从新输入:");
returnRiQi = sc.nextInt();
}
}
System.out.println("归还成功!!!");
//更新借阅状态
states[i] = 0;
/*//更新借阅次数
borrowCounts[i]++;*/
break;
}else if(bookNames[i]!=null && bookNames[i].equals(returnName) && states[i] == 0){
//如果可以找到书,且书的状态是可借阅,不能归还
isReturn = true;
System.out.println("书可借阅,不能归还!");
break;
}
}
if(!isReturn){
//bookNames[i] == null.说明找不到书,不可以归还
System.out.println("抱歉,不是本图书馆的书,不用归还!!!");
break;
}
break;
case 5:
System.out.println("5.删除图书");
System.out.print("请输入您要删除图书的名字:");
String deleteName = sc.next();
boolean isDelete = false;//true:能删 false:不能删
for(int i = 0;i<bookNames.length;i++){
/*//if(!bookNames[i].equals(borrowName))
if(bookNames[i] == null){
//找不到书,不能删
isDelete = false;
break;
}else*/
if(bookNames[i] != null && bookNames[i].equals(deleteName) && states[i] == 1){
//如果可以找到书,且书的状态是已借出,不能删除
isDelete = true;
System.out.println("书已借出,不能删除!");
break;
}else if(bookNames[i] != null && bookNames[i].equals(deleteName) && states[i] == 0){
//如果可以找到书,且书的状态是可借阅,可以删除
isDelete = true;
//初始化呢index,用来记录下需要删除的位置
int index = -1;
if(bookNames[i].equals(deleteName)){
index = i;
}
//判断index是-1还是i
if(index != -1){
//index不是-1,说明找到了图书,可以删除
for(i = index;i<bookNames.length-1;i++){
//从下标index1开始,后面的整体向前移一位
bookNames[i] = bookNames[i+1];
borrowDates[i] = borrowDates[i+1];
borrowCounts[i] = borrowCounts[i+1];
states[i] = states[i+1];
//最后一位置空
bookNames[bookNames.length-1] = null;
borrowDates[bookNames.length-1] = 0;
borrowCounts[bookNames.length-1] = 0;
states[bookNames.length-1] = 0;//0:可借阅 1:已借出
}
}
System.out.println("删除图书成功!");
break;
}
}
if(!isDelete){
//bookNames[i] == null.说明找不到书,不能删除
System.out.println("不是本图书馆的书,不能删除");
break;
}
break;
case 6:
flag = false; //退出系统
break;
default:
flag = false; //退出系统
break;
}
if(flag){
System.out.print("\n输入0返回:");
num = sc.nextInt();
}else{
break;
}
}while(num == 0);
System.out.println("谢谢使用!!!");
}
}
ps:本人也在学Java开发,也是刚入门不久,所以也有些Java开发的资料,以及计算机相关的电子书等资料,所以有想要的小伙伴可以多多互动哦,一起多交流交流!!!O(∩_∩)O
迷你图书管理系统 源代码 Java初级小项目的更多相关文章
- 吃货联盟订餐系统 源代码 Java初级小项目
咳咳,今天博主给大家写一个小的项目:吃货联盟订餐系统.博主不是大神(互联网架构师的路上ing),也是小白一个,不过是刚入门的小白^_^.项目功能也很简单:只是模拟日常的订餐流程呦,所以有错误以及功能不 ...
- 嗖嗖移动大厅 源代码 Java初级小项目
今天给大家一个比较综合的项目:嗖嗖移动业务大厅.项目功能很多,概括的功能也很全面.吃透了这个项目,你的java基础部分已经非常棒了!!! 一 . 项目概述 技能要求 使用面向对象设计的思想 合 ...
- 小项目,吃货联盟,java初级小项目,源代码
1:项目的实现效果.功能如图所示. 2:项目的源代码如下: import java.util.Scanner; /** * 吃货联盟订餐管理系统 * */ public class OrderingM ...
- 掷骰子游戏窗体实现--Java初级小项目
掷骰子 **多线程&&观察者模式 题目要求:<掷骰子>窗体小游戏,在该游戏中,玩家初始拥有1000的金钱,每次输入押大还是押小,以及下注金额,随机3个骰子的点数,如果3个骰 ...
- Java小项目迷你图书管理系统
package 迷你图书管理系统; import java.util.Scanner; public class BookMgr { public static void main(String[] ...
- java初学小项目-酒店客房管理系统
最近初次接触JAVA,感觉之前学的C语言很有用,跟着视频做了一个小项目-酒店客房管理系统 /* 酒店客房管理系统 */ import java.util.Scanner;//通过键盘来输入命令需要的引 ...
- 图书管理系统(Java实现,十个数据表,含源码、ER图,超详细报告解释,2020.7.11更新)
图书管理系统数据库设计实验报告 文章目录 更新日志 1.概述 2.需求分析 2.1需要实现的功能 2.2业务流程图 2.2.1学生流程图 2.2.2管理员流程图 2.2.3超级管理员流程图 2.3功能 ...
- 图书管理系统总结——JAVA Swing控件简介
断断续续学习JAVA语言,写了一个多月数据库大作业,终于在五一过后写完了.由于第一次使用JAVA和数据库,遇到了许多问题,记录下来,以备以后查看. 我使用的JAVA SE,说实话,在开发后期,觉得JA ...
- Java数据库小项目02--管家婆项目
目录 项目要求 开发环境搭建 工具类JDBCUtils 创建管家婆数据表 项目分层 MainApp层 MainView层 ZhangWuController层 ZhangWuService层 Zhan ...
随机推荐
- PHP获取临时文件的目录路径
PHP获得临时文件的文件目录相对路径,能够 根据tempnam()和sys_get_temp_dir()函数来完成. 下边我们运用简单的代码实例,给大伙儿介绍PHP获得临时文件的文件目录相对路径的方式 ...
- Rocket - tilelink - Fuzzer
https://mp.weixin.qq.com/s/hAKpZHy0IU6_XEvctfkHOA 简单介绍Fuzzer的实现. 1. IDMapGenerator 功能类似于I ...
- jchdl - GSL Port
https://mp.weixin.qq.com/s/DVmMrCFgNLuZDtssQ85w7A org.jchdl.model.gsl.core.meta.Port.java gen ...
- [leetcode] 动态规划(Ⅰ)
这次按通过率从高到低刷题. 本文完成的题目:{338, 1025, 303, 121, 53, 392, 70, 746, 198} ,带有「面试」Tag 的题目:Interview - {1617, ...
- Web 三维组态的仿真运用案例:民航飞机的数据监控
前言 在飞机航行的过程中,客舱里座位上方的荧屏上,除了播放电视剧和广告之外,还会时不时的切换到一个飞机航行的监控系统.这个监控系统的主要目的是,让乘客可以了解到飞机在航行过程中的整体状况.距离目的地的 ...
- Java实现 LeetCode 822 翻转卡片游戏(暴力)
822. 翻转卡片游戏 在桌子上有 N 张卡片,每张卡片的正面和背面都写着一个正数(正面与背面上的数有可能不一样). 我们可以先翻转任意张卡片,然后选择其中一张卡片. 如果选中的那张卡片背面的数字 X ...
- Java实现蓝桥杯VIP算法训练 自行车停放
试题 算法训练 自行车停放 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 有n辆自行车依次来到停车棚,除了第一辆自行车外,每辆自行车都会恰好停放在已经在停车棚里的某辆自行车的左边或 ...
- Java实现 蓝桥杯VIP 算法训练 连接字符串
算法训练 连接字符串 时间限制:1.0s 内存限制:512.0MB 编程将两个字符串连接起来.例如country与side相连接成为countryside. 输入两行,每行一个字符串(只包含小写字母, ...
- Java实现 LeetCode 118 杨辉三角
118. 杨辉三角 给定一个非负整数 numRows,生成杨辉三角的前 numRows 行. 在杨辉三角中,每个数是它左上方和右上方的数的和. 示例: 输入: 5 输出: [ [1], [1,1], ...
- Java实现 LeetCode 78 子集
78. 子集 给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: nums = [1,2,3] 输出: [ [3], [1], ...