以Java为例,实现一个简单的命令行图书管理系统,包括添加图书、删除图书、查找图书等功能。

江河湖海中的代码之旅:打造你的命令行图书管理系统

一、系统简介

1. Java简介

Java,这个编程语言界的“瑞士军刀”,自1995年诞生以来就以其跨平台的特性和强大的生态系统征服了无数开发者的心。想象一下,Java就像是一条蜿蜒曲折但又充满活力的长江,它从高山出发,穿越平原,最终汇入广阔的大海——也就是我们的计算机世界。无论你是在Windows的森林里探险,还是在macOS的草原上奔跑,甚至是在Linux的沙漠中漫步,只要有JVM(Java虚拟机)作为你的船,你就能畅游无阻。

2. 命令行图书管理系统概述

现在让我们把目光投向一个更加具体的场景:一个基于Java开发的命令行图书管理系统。这不仅仅是一个简单的软件项目,它是你与知识海洋之间架起的一座桥梁。通过这个项目,你可以学会如何利用Java来处理文件I/O操作、用户输入输出以及基本的数据结构等核心概念。想象一下,每当你成功添加一本新书到系统中时,就像是在这片知识的海洋里投下了一颗石子,激起一圈圈涟漪;而当你删除或查找某本书时,则像是在这片波涛汹涌的海面上寻找属于自己的那一片宁静之地。


二、功能实现

1. 添加图书

1.1 输入图书信息

首先,我们需要定义一个Book类来表示书籍对象。这个类应该包含书名、作者、ISBN编号等属性,并提供相应的构造函数和方法来访问这些属性。接下来,我们将编写一段代码来读取用户通过控制台输入的信息,并将其转化为Book实例。

import java.util.Scanner;class Book {private String title;private String author;private String isbn;public Book(String title, String author, String isbn) {this.title = title;this.author = author;this.isbn = isbn;}// Getters and setters omitted for brevity}
public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);System.out.println("请输入书名:");String title = scanner.nextLine();System.out.println("请输入作者:");String author = scanner.nextLine();System.out.println("请输入ISBN编号:");String isbn = scanner.nextLine();Book book = new Book(title, author, isbn);// 后续步骤...}}```#### 1.2 将图书信息存储到文件或数据库中一旦我们有了`Book`对象,下一步就是将其保存起来以便日后使用。这里有两种常见的方法:直接写入文本文件或者使用数据库进行管理。为了简单起见,我们这里选择前者。我们可以创建一个名为`books.txt`的文件,并将每本新添加的书籍按照一定格式写入其中。```javaimport java.io.FileWriter;import java.io.IOException;
// ... 前面的代码保持不变 ...try (FileWriter writer = new FileWriter("books.txt", true)) {writer.write(book.getTitle() + "," + book.getAuthor() + "," + book.getIsbn() + "");} catch (IOException e) {e.printStackTrace();}```请注意,上述示例仅展示了最基本的错误处理方式。实际应用中可能需要更复杂的逻辑来确保数据完整性和安全性。
### 2. 删除图书
#### 2.1 根据书名查找图书
要删除一本书之前,首先得找到它。这意味着我们需要遍历整个`books.txt`文件,检查每一行是否匹配给定的书名。如果找到了匹配项,则记录下该行的索引位置以便稍后删除。
```java
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;// ... 前面的代码保持不变 ...public static int findBookIndexByTitle(String title) throws IOException {List<String> lines = new ArrayList<>();try (BufferedReader reader = new BufferedReader(new FileReader("books.txt"))) {String line;while ((line = reader.readLine()) != null) {lines.add(line);}}for (int i = 0; i < lines.size(); i++) {if (lines.get(i).startsWith(title)) {return i;}}return -1; // Not found}```#### 2.2 从文件或数据库中删除图书信息一旦我们知道了要删除的书籍所在的位置,接下来就可以执行实际的删除操作了。同样地,这里以文本文件为例说明过程。我们会重新打开`books.txt`,但是这次是以覆盖模式写入除了目标行之外的所有内容。```javaimport java.io.RandomAccessFile;import java.nio.channels.FileChannel;import java.nio.channels.FileLock;
// ... 前面的代码保持不变 ...public static void deleteBook(String title) {int index = findBookIndexByTitle(title);if (index == -1) {System.out.println("未找到指定书籍!");return;}try (RandomAccessFile raf = new RandomAccessFile("books.txt", "rw");FileChannel channel = raf.getChannel();FileLock lock = channel.lock()) {raf.seek(0); // Move to the beginning of the fileStringBuilder sb = new StringBuilder();for (int i = 0; i < lines.size(); i++) {if (i != index) {sb.append(lines.get(i)).append("");}}raf.setLength(0); // Truncate the fileraf.write(sb.toString().getBytes()); // Write back modified content} catch (IOException e) {e.printStackTrace();}}```请注意,上述代码片段使用了`RandomAccessFile`和`FileChannel`来实现对文件的安全访问。这样做可以防止多个进程同时修改同一个文件导致的数据竞争问题。当然,如果你打算部署到生产环境,可能还需要考虑更多因素如事务支持、并发控制等。
### 3. 查找图书
#### 3.1 根据书名在文件或数据库中查找图书
查找功能其实已经在删除部分有所涉及,即通过遍历整个`books.txt`文件来搜索特定书名的书籍。不过,为了让这部分内容更加独立清晰,我们可以将其封装成一个单独的方法。
```java
public static Book findBookByTitle(String title) throws IOException {int index = findBookIndexByTitle(title);if (index == -1) {return null; // Not found} else {String[] parts = lines.get(index).split(",");return new Book(parts[0], parts[1], parts[2]);}}```#### 3.2 输出查找结果最后一步就是向用户展示查找结果啦!根据前面的方法返回的结果,我们可以很容易地打印出相关信息。如果找到了对应的书籍,则显示其详细信息;否则提示用户没有找到匹配项。```javapublic static void displaySearchResult(String title) {try {Book book = findBookByTitle(title);if (book != null) {System.out.println("找到书籍:");System.out.println("书名: " + book.getTitle());System.out.println("作者: " + book.getAuthor());System.out.println("ISBN: " + book.getIsbn());} else {System.out.println("未找到指定书籍!");}} catch (IOException e) {e.printStackTrace();}}```---好了,以上就是关于如何使用Java构建一个简单的命令行图书管理系统的详细介绍。希望通过这篇博客能够激发你对编程的兴趣,并且鼓励你去尝试自己动手实现这样一个有趣的小项目。记住,实践是最好的老师!加油吧,未来的程序员们!💪🌟

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/20298.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

硬件知识 cadence16.6 原理图输出为pdf 网络名下划线偏移 (ORCAD)

1. cadence原理图输出为PDF网络名下划线偏移 生这种情况的原因 1. 设计的原理图图纸大小比正常的 A4图纸大。 2. 打印为PDF 的时候&#xff0c;打印机的设置有问题。 2.cadence原理图输出为 PDF网络名下划线偏移的情况 可以看到上图&#xff0c;网络名往上漂移。 3. 解决办法 …

Linux插件zsh(oh-my-zsh)

一、oh-my-zsh基本介绍 oh-my-zsh&#xff1a; https://github.com/ohmyzsh/ohmyzshhttps://github.com/ohmyzsh/ohmyzsh 注意&#xff1a;需要先安装zsh命令&#xff0c;才能安装oh-my-zsh&#xff0c;先测试是否安装了zsh rootserver:/opt # zsh --version zsh 5.8 (x86_6…

异或和之和

//暴力做法 枚举每个子区间 O(n^3) //优化1 利用前缀异或和快速求出区间异或和 O(n^2) //优化2 处理位运算的常用方法&#xff1a;拆位法 常用的思想&#xff1a;贡献法思想 下面详见优化2&#xff1a; 1.拆位贡献法 2.实战真题1 题目链接&#xff1a;1.异或和之和 - 蓝桥…

A039-基于SpringBoot的农产品销售系统的设计与实现

&#x1f64a;作者简介&#xff1a;在校研究生&#xff0c;拥有计算机专业的研究生开发团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339; 赠送计算机毕业设计600…

【大数据学习 | Spark】RDD的概念与Spark任务的执行流程

1. RDD的设计背景 在实际应用中&#xff0c;存在许多迭代式计算&#xff0c;这些应用场景的共同之处是&#xff0c;不同计算阶段之间会重用中间结果&#xff0c;即一个阶段的输出结果会作为下一个阶段的输入。但是&#xff0c;目前的MapReduce框架都是把中间结果写入到HDFS中&…

jmeter操作数据库

简介 Apache JMeter 是一个强大的开源工具&#xff0c;用于负载测试和性能测量。除了Web应用外&#xff0c;JMeter还可以用于测试各种数据库系统&#xff0c;包括MySQL。本文将详细介绍如何使用JMeter来测试MySQL数据库的性能。 环境准备 安装Java&#xff1a;确保你已经安装…

最小生成树——Kruskal、Prim算法

图的存储&#xff1a; 高阶数据结构——图 文章目录 目录 文章目录 一、kruskal算法 二、Prim算法 前言 连通图中的每一棵生成树&#xff0c;都是原图的一个极大无环子图&#xff0c;即&#xff1a;从其中删去任何一条边&#xff0c;生成树 就不在连通&#xff1b;反之&#xf…

STL-stack栈:P1981 [NOIP2013 普及组] 表达式求值

这个题用的STL-栈来做 题目来源&#xff1a;洛谷 相关知识 [NOIP2013 普及组] 表达式求值 题目背景 NOIP2013 普及组 T2 题目描述 给定一个只包含加法和乘法的算术表达式&#xff0c;请你编程计算表达式的值。 输入格式 一行&#xff0c;为需要你计算的表达式&#xff…

数字孪生赋能智慧校园:构建全方位校园安全保障新体系

在11月19日最高人民检察院的党组会上&#xff0c;校园安全问题再次被置于重要议程&#xff0c;会议明确指出&#xff0c;校园安全不仅关乎学生的健康成长&#xff0c;更与社会和谐稳定紧密相连。面对侵害学生权益、危害校园安全的犯罪行为&#xff0c;必须采取“零容忍”态度&a…

Openstack15--块存储服务(Cinder)安装

控制节点 安装Cinder软件包 yum -y install openstack-cinder 安装的“openstack-cinder”软件包里包括“cinder-api”和“cinder-scheduler”模块。安装“openstack-cinder”软件包时&#xff0c;和安装其他OpenStack核心组件时一样&#xff0c;会自动创建名为“cinder”的L…

如何用js方法把页面中的表格导出为excel表格(sheetJS)

目录 一&#xff0c;SheetJS库的基本介绍 这里用到的库是SheetJS&#xff0c;官方文档&#xff1a; sheetJS CE 官方文档 官网对库的解释是&#xff1a; SheetJS社区版提供了经过战斗测试的开源解决方案&#xff0c;用于从几乎任何复杂的电子表格中提取有用的数据&#xf…

自动驾驶系列—告别眩光烦恼:智能大灯如何守护夜间行车安全

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

爬虫策略——反爬机制

现代网站通常会使用多种反爬手段来限制爬虫访问数据。了解这些机制并针对性地制定绕过策略&#xff0c;是构建高效爬虫的关键。 1. 常见反爬手段 1.1 User-Agent 检查 网站通常会通过检查请求中的 User-Agent 字段&#xff0c;判断访问是否来自真实用户。爬虫默认的请求库&am…

DataWhale—PumpkinBook(TASK03对数几率回归)

一、课程组成及结构 课程开源地址及相关视频链接&#xff1a;&#xff08;当然这里也希望大家支持一下正版西瓜书和南瓜书图书&#xff0c;支持文睿、秦州等等致力于开源生态建设的大佬✿✿ヽ(▽)ノ✿&#xff09; Datawhale-学用 AI,从此开始 【吃瓜教程】《机器学习公式详解…

系统安全第十三次作业题目及答案

一、 1.计划 实施 检查 处置 2.物理 系统 运行 数据 人员 技术文档 3.物理 网络 系统 应用 管理 二、 1.C 2.B 3.A 4.ACDE 5.ABCD 三、 1. 答&#xff1a; 概念&#xff1a;信息系统安全管理指通过计划、组织、领导、控制等环节来协调人力、物力、财力等资源&#x…

Qml 模型-视图-代理(贰)之 代理(Delegate) 学习

使用模型与视图来定义用户界面时&#xff0c;代理在创建显示时扮演了大量的角色&#xff0c;在模型中的每个元素通过代理来实现可视化。 代理 使用键盘移动 高亮 效果 代码&#xff1a; 视图绑定的属性是 ListView.isCurrentItem: 这个属性是一个布尔值&#xff0c;标识这…

LeetCode 面试经典 150 题回顾

目录 一、数组 / 字符串 1.合并两个有序数组 &#xff08;简单&#xff09; 2.移除元素 &#xff08;简单&#xff09; 3.删除有序数组中的重复项 &#xff08;简单&#xff09; 4.删除有序数组中的重复项 II&#xff08;中等&#xff09; 5.多数元素&#xff08;简单&am…

内外网交换过程中可能遇到的安全风险有哪些?

在数字化时代&#xff0c;企业内外网之间的数据交换变得日益频繁。然而&#xff0c;这一过程中的安全风险和效率问题也日益凸显。我们将探讨内外网交换可能遇到的安全风险&#xff0c;并介绍镭速内外网交换系统如何有效应对这些挑战。 内外网交换过程中的五大安全风险 数据泄露…

人工智能之机器学习概念3【培训机构学习笔记】

定义及作用&#xff1a; 无监督学习是通过试图学习或提取数据背后的数据特征&#xff0c;或者从数据中抽取出重要的特征信息&#xff0c;常见的算法有类聚、降维、文本处理&#xff08;特征抽取&#xff09;等。无监督学习一般是作为有监督学习的前期数据处理&#xff0c;功能…

文件系统的存储方式

磁盘是一个机械设备&#xff0c;外设。 磁盘的基本单位是扇区&#xff0c;一个扇区512字节&#xff0c;4KB。一片可以有n磁道&#xff0c;1磁道可以有m扇区。 如何找到指定位置的扇区&#xff1f;a.找到指定的磁头H b.找到指定的磁道(柱面)C c.找到指定的扇区S。这个叫CHS定址法…