今天博主再给大家分享一个小项目: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初级小项目的更多相关文章

  1. 吃货联盟订餐系统 源代码 Java初级小项目

    咳咳,今天博主给大家写一个小的项目:吃货联盟订餐系统.博主不是大神(互联网架构师的路上ing),也是小白一个,不过是刚入门的小白^_^.项目功能也很简单:只是模拟日常的订餐流程呦,所以有错误以及功能不 ...

  2. 嗖嗖移动大厅 源代码 Java初级小项目

    今天给大家一个比较综合的项目:嗖嗖移动业务大厅.项目功能很多,概括的功能也很全面.吃透了这个项目,你的java基础部分已经非常棒了!!! 一 . 项目概述 技能要求  使用面向对象设计的思想  合 ...

  3. 小项目,吃货联盟,java初级小项目,源代码

    1:项目的实现效果.功能如图所示. 2:项目的源代码如下: import java.util.Scanner; /** * 吃货联盟订餐管理系统 * */ public class OrderingM ...

  4. 掷骰子游戏窗体实现--Java初级小项目

    掷骰子 **多线程&&观察者模式 题目要求:<掷骰子>窗体小游戏,在该游戏中,玩家初始拥有1000的金钱,每次输入押大还是押小,以及下注金额,随机3个骰子的点数,如果3个骰 ...

  5. Java小项目迷你图书管理系统

    package 迷你图书管理系统; import java.util.Scanner; public class BookMgr { public static void main(String[] ...

  6. java初学小项目-酒店客房管理系统

    最近初次接触JAVA,感觉之前学的C语言很有用,跟着视频做了一个小项目-酒店客房管理系统 /* 酒店客房管理系统 */ import java.util.Scanner;//通过键盘来输入命令需要的引 ...

  7. 图书管理系统(Java实现,十个数据表,含源码、ER图,超详细报告解释,2020.7.11更新)

    图书管理系统数据库设计实验报告 文章目录 更新日志 1.概述 2.需求分析 2.1需要实现的功能 2.2业务流程图 2.2.1学生流程图 2.2.2管理员流程图 2.2.3超级管理员流程图 2.3功能 ...

  8. 图书管理系统总结——JAVA Swing控件简介

    断断续续学习JAVA语言,写了一个多月数据库大作业,终于在五一过后写完了.由于第一次使用JAVA和数据库,遇到了许多问题,记录下来,以备以后查看. 我使用的JAVA SE,说实话,在开发后期,觉得JA ...

  9. Java数据库小项目02--管家婆项目

    目录 项目要求 开发环境搭建 工具类JDBCUtils 创建管家婆数据表 项目分层 MainApp层 MainView层 ZhangWuController层 ZhangWuService层 Zhan ...

随机推荐

  1. Postgre数据库自定义函数

    自定函数 1.查询函数: select prosrc from pg_proc where proname='test' 参数说明 : test 为函数名. 2.删除函数: drop function ...

  2. 【JVM】垃圾回收的四大算法

    GC垃圾回收 JVM大部分时候回收的都是新生代(伊甸区+幸存0区+幸存1区).按照回收的区域可以分成两种类型:Minor GC和Full GC(MajorGC). Minor GC:只针对新生代区域的 ...

  3. Rocket - diplomacy - 模块结构信息

    https://mp.weixin.qq.com/s/cTRxXwWNEeb4-XX_t4bRcg   讨论模块结构信息的来源及使用方式.     ​​   1. diplomacy   diplom ...

  4. Rocket - decode - Simplify

    https://mp.weixin.qq.com/s/YWXYNaRU-DbLOMxpzF2bpQ   介绍Simplify如何简化解码逻辑.     1. 使用   Simplify在DecodeL ...

  5. Java实现 LeetCode 747 至少是其他数字两倍的最大数(暴力)

    747. 至少是其他数字两倍的最大数 在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素的索引,否则返回-1. 示例 ...

  6. Java实现 LeetCode 668 乘法表中第k小的数(二分)

    668. 乘法表中第k小的数 几乎每一个人都用 乘法表.但是你能在乘法表中快速找到第k小的数字吗? 给定高度m .宽度n 的一张 m * n的乘法表,以及正整数k,你需要返回表中第k 小的数字. 例 ...

  7. Java实现 蓝桥杯 算法提高 周期字串

    算法提高 周期字串 时间限制:1.0s 内存限制:256.0MB 问题描述 右右喜欢听故事,但是右右的妈妈总是讲一些"从前有座山,山里有座庙,庙里有个老和尚给小和尚讲故事,讲的什么呢?从前有 ...

  8. Java实现 蓝桥杯 算法提高 Monday-Saturday质因子

    试题 算法提高 Monday-Saturday质因子 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 这个问题是个简单的与数论有关的题目,看起来似乎是"求正整数的所有质因子 ...

  9. Dockerfile 解析

    Dockerfile Dockerfile是用来构建Docker镜像的构建文件,是由一系列参数和命令构成的脚本. 构建的三个步骤:1.编写Dockerfile文件  2.docker build  3 ...

  10. Python爬虫 爬取搜狗搜索到的内容页面

    废话不多说,直接上代码 import requests def main(): url='https://www.sogou.com/web' headers={ 'User_Agent':'Mozi ...