迷你图书管理系统 源代码 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 ...
随机推荐
- [Python进阶]002.装饰器(1)
装饰器(1) 介绍 HelloWorld 需求 使用函数式编程 加入装饰器 解析 介绍 Python的装饰器叫Decorator,就是对一个模块做装饰. 作用: 为已存在的对象添加额外功能. 与Jav ...
- volatile关键字与内存可见性&原子变量与CAS算法
1 .volatile 关键字:当多个线程进行操作共享数据时, 可以保证内存中的数据可见 2 .原子变量:jdk1.5后java.util.concurrent.atomic 包下提供常用的原子变量 ...
- C/C++多参数函数参数的计算顺序与压栈顺序
一.前言 今天在看Thinking in C++这本书时,书中的一个例子引起了我的注意,具体是使用了下面这句 单看这条语句的语义会发现仅仅是使用一个简单的string的substr函数将所得子串pus ...
- Java-语言基础梳理
1.java命名规范 包名:全小写 类名,接口名:首字母大写 变量名,方法名:第一个单词皆字母小写,后面单词首字母大写 常量名:所有字母都大写 2.变量 2.1 注意事项 作用域:一对{}之间有用 必 ...
- python常见面试题讲解(十三)字串的连接最长路径查找
输入描述: 输入第一行为一个正整数n(1≤n≤1000),下面n行为n个字符串(字符串长度≤100),字符串中只含有大小写字母. 输出描述: 数据输出n行,输出结果为按照字典序排列的字符串. 示例1 ...
- elasticsearch中保存时间格式
利用logstash从文档中导入数据到es中,若未事先设定数据格式,有可能存储时间并未保存为date格式而是text格式. 时间若保存为text,则在会以字符串数组格式存储在es中,是乱序,不好查询. ...
- CPU亲和度
CPU亲和度(CPU Affinity),就是将一个进程或者线程强制绑定在CPU的某一个core上运行. 参考:https://www.cnblogs.com/zhangxuan/p/6427533. ...
- Java实现复数运算
1 问题描述 编程实现两个复数的运算.设有两个复数 和 ,则他们的运算公式为: 要求:(1)定义一个结构体类型来描述复数. (2)复数之间的加法.减法.乘法和除法分别用不用的函数来实现. (3)必须使 ...
- Java实现计数排序
1 问题描述 给定一组数据,请使用计数排序,得到这组数据从小到大的排序序列. 2 解决方案 2.1比较计数排序 下面算法的时间复杂度为O(n^2),空间复杂度为O(n).此方法对于任意一组数据均可排序 ...
- 原生js ajax 封装
首先我们先了解ajax的get和post请求分别是怎样请求数据的 get请求 let ajx = new XMLHttpRequest() //创建ajax实例 /*打开需要请求的地址,可以有三个参数 ...