Java图书管理系统(简易保姆级)

news2025/1/1 22:21:00

前面学习了这么多知识,为了巩固之前的知识,我们就要写一个图书管理系统来帮助大家复习,让大家的知识融会贯通~~~

话不多说,直接开始今天的内容~


首先呢,我们要有一个大体的思路:

实现效果思路有两种情况:

1.实现普通用户

输入用户名->

Re.不晚

选择身份:  1->管理员   2->普通用户

2

欢迎Re.不晚来到图书管理系统
******普通用户菜单******
1 借阅图书
2 查找图书
3 显示图书
4 归还图书
0 退出系统
********************

2.实现管理员

输入用户名->

Re.不晚

选择身份:  1->管理员   2->普通用户

1

欢迎Re.不晚来到图书管理系统
******管理员菜单******
1 增加图书
2 查找图书
3 删除图书
4 显示图书
0 退出系统
********************

到这一步 ,我们就有了一个大体思路了,首先使用这个系统有两类人,第一类人是普通用户,第二类人是系统管理员

我们先来定义一个User的包,然后有一个User的类作为父类,然后再创建普通用户NormalUser和图书系统管理员AdminUser,不管是普通用户还是系统管理员都将作为子类继承父类

那我们先来说一下User类怎么写,首先不管你是普通用户还是系统管理员,我们都要输入一下名字 ,所以这个类里面就有了名字~

package User;

public class User {
    public String name;

    public User(String name) {
        this.name = name;
    }
}

然后另外两个子类要继承这个父类,我们的代码如下:

package User;
import java.util.Scanner;

public class NormalUser extends User {
    public NormalUser(String name) {
        super(name);//用super访问父类的名字属性
    }
}
package User;
import java.util.Scanner;

public class AdminUser extends User{
    public AdminUser(String name) {
        super(name);//用super访问父类属性
    }
}

之后,我们就要选择身份了,选择完身份,我们就需要进入菜单了,不管是哪个子类都有菜单,如果选择了1 就进入AdminUser的菜单,如果选择了2 就进入NormalUser的菜单,我们把菜单抽象到User类里面,那么此时User就变成了抽象类,那么三个类的代码如下:

package User;

public abstract class User {
    public String name;

    public User(String name) {
        this.name = name;
    }

    public abstract int menu();
}
package User;
import java.util.Scanner;

public class NormalUser extends User {
    public NormalUser(String name) {
        super(name);
    }

    @Override
    public int menu() {//重写User类里面的抽象方法,也就是菜单
        System.out.println("欢迎"+this.name+"来到图书管理系统");
        System.out.println("******普通用户菜单******");
        System.out.println("1 借阅图书");
        System.out.println("2 查找图书");
        System.out.println("3 显示图书");
        System.out.println("4 归还图书")
        System.out.println("0 退出系统");
        System.out.println("********************");
        Scanner sc = new Scanner(System.in);//由于要在菜单里面选择0~3的数字,所以我们要返回用户输入的值
        int choice = sc.nextInt();//用户在菜单中选择
        return choice;//返回用户的选择

    }
}
package User;
import java.util.Scanner;

public class AdminUser extends User{

    public AdminUser(String name) {
        super(name);
    }

    @Override
    public int menu() {
        System.out.println("欢迎"+this.name+"来到图书管理系统");
        System.out.println("******管理员菜单******");
        System.out.println("1 增加图书");
        System.out.println("2 查找图书");
        System.out.println("3 删除图书");
        System.out.println("4 显示图书");
        System.out.println("0 退出系统");
        System.out.println("********************");
        Scanner sc = new Scanner(System.in);//由于管理员要选择0~4之间的数字,所以我们要输入一个数字
        int choice = sc.nextInt();//管理员输入一个0~4之间的数字
        return choice;//返回管理员选择的数字
    }
}

那这个时候,前面铺垫的差不多了,我们就要写一个登录系统来串一下整体的逻辑,代码如下(有注释):

import User.AdminUser;
import User.NormalUser;
import User.User;
import java.util.Scanner;

public class Main {
    public static User login(){   //由于这里要返回AdminUser或者NormalUser,所以这里的login()方法是User类
        Scanner sc = new Scanner(System.in);
        System.out.println("Enter your username: ");
        String name = sc.nextLine();//这里就是输入你的名字

        System.out.println("Enter your identity: 1->AdminUser 2->NormalUser");
        int choice = sc.nextInt();//这里就是输入你的选择,选1就是AdminUser,选2就是NormalUser

        if(choice == 1){
            return new AdminUser(name);//如果选择1,那么就返回AdminUser的类
        }else if(choice == 2){
            return new NormalUser(name);//如果选择2,那么就返回NormalUser的类
        }
    }

    public static void main(String[] args) {
        User user = login();//由于这里要返回AdminUser或者NormalUser,所以这里的login()方法是User类,所以当新建一个对象也是User类
    }
}

那用户方面我们大体写出来了,接下来我们该考虑图书了,首先,我们需要建立一个书架,上面放着书,一本书有作者,价格,书名,类型,有没有被借走这几种状态,那么我们就可以先建立一个包~

然后在Book类里面,有这么几种属性,书名,作者,价格,类型,借走状态(代码如下):

package BookShelf;

public class Book {
    private String name;
    private String author;
    private int price;
    private String type;
    private boolean isborrowed;

    public Book(String name, String author, String type, int price) {
        this.name = name;
        this.author = author;
        this.type = type;
        this.price = price;
        this.isborrowed = false;
    }//构造方法

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public int getPrice() {
        return price;
    }

    public void setPrice(int price) {
        this.price = price;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public boolean isborrowed() {
        return isborrowed;
    }

    public void setborrowed(boolean isborrowed) {
        this.isborrowed = isborrowed;
    }

    //这里重写了toString的方法,在进行new对象时,输出这个对象时就是这里的输出格式
    @Override
    public String toString() {
        return "Book{" +
                "name='" + name + '\'' +
                ", author='" + author + '\'' +
                ", price=" + price +
                ", type='" + type + '\'' +
                ", isborrowed=" + isborrowed +
                '}';
    }
}

然后在另一个BookList类里,则代表关于存放几本书,具体的书籍初始化等问题,而且要把Book创建成一个数组,每个数组里面,包含Book类的属性,代码如下:

package BookShelf;

public class BookList {
    private Book[] books;//创建Book类型的数组
    private static final int default_size = 10;//数组的大小
    private int validSzie;//有效书籍个数

    public BookList() {
        this.books = new Book[default_size];//创建一个大小为10的Book类数组

        //假设刚开始这个系统存放了三本书
        this.books[0] = new Book("Book 1", "Author 1", "ISBN 1", 2000);
        this.books[1] = new Book("Book 2", "Author 2", "ISBN 2", 3000);
        this.books[2] = new Book("Book 3", "Author 3", "ISBN 3", 4000);

        //有效书籍个数为3
        this.validSzie = 3;
    }

    //若调用此方法,则打印所有书籍(具体在Book类里 toString 方法实现打印)
    public Book[] getBooks() {
        return books;
    }


    //调用此方法则获得有效书籍的个数
    public int getValidszie() {
        return validSzie;
    }

    //若调用此方法则可以赋值效书籍的个数
    public void setValidSzie(int validszie) {
        this.validSzie = validszie;
    }

    //若调用此方法,则打印一本书籍的信息
    public Book getBooks(int pos) {
        return books[pos];
    }

    //若调用此方法,则可以增加一本书,对书进行初始化
    public void setBooks(int pos, Book book) {
        books[pos] = book;
    }
}

那么书架我们也写好了,在串联用户和书架时,我们突然想到有这么一个步骤,用户选择了菜单中一项内容,然后我门要对书架进行增删查改,这个时候,我们就通过菜单的功能串联起来了,前面我们讲到菜单的返回是一个整数,那么我们要针对选择的整数,进行一个功能上的选择,那么我们应该怎么做呢?

答案就是,把这些功能,放到 一个数组里面!

那么我们的包就可以这样创建:

在这些功能中,都有各自的方法,每个方法都不一样,但是他们都有功能,那么这个时候,我们就想到了接口,把功能写到这个接口里,后面不管写哪个具体的功能都要进行重写,代码如下:

package operation;
import BookShelf.BookList;

public interface IOperation {
    void work(BookList bookList);
}

考虑到当我们初始化普通用户或者是管理员的功能不同,我们在User类里面,创建这个功能数组~

那么User类的代码如下:

package User;
import BookShelf.BookList;
import operation.IOperation;

public abstract class User {
    public String name;
    public IOperation[] ioPerations;//创建的功能数组

    public User(String name) {
        this.name = name;
    }

    public abstract int menu();

    public void doOperations(int choice, BookList books) {
        IOperation iOperation = this.ioPerations[choice];//这里指的是创建功能数组时,由于菜单那里返回的是用户选择的一个整数,那么我们就对应到数组中具体的那个功能
        iOperation.work(books);//调用不同功能中的方法~
    }
}

 那我们其它两个子类的代码如下:

package User;

import operation.*;

import java.util.Scanner;

public class NormalUser extends User {
    public NormalUser(String name) {
        super(name);

        //初始化功能数组,把功能放到数组里面,因为功能都有一个共同的接口,所以数组的类型为IOperation
        this.ioPerations = new IOperation[]{
                new ExitBook(),//数组下标为0,功能为退出系统(其他几行以此类推)
                new BorrowBook(),
                new FindBook(),
                new ShowBook(),
                new ReturnBook()
        };
    }

    @Override
    public int menu() {
        System.out.println("欢迎"+this.name+"来到图书管理系统");
        System.out.println("******普通用户菜单******");
        System.out.println("1 借阅图书");
        System.out.println("2 查找图书");
        System.out.println("3 显示图书");
        System.out.println("4 归还图书")
        System.out.println("0 退出系统");
        System.out.println("********************");
        Scanner sc = new Scanner(System.in);
        int choice = sc.nextInt();
        return choice;

    }
}
package User;

import operation.*;

import java.util.Scanner;

public class AdminUser extends User{

    public AdminUser(String name) {
        super(name);

        //初始化功能数组
        this.ioPerations = new IOperation[]{
                new AddBook(),
                new FindBook(),
                new DeleteBook(),
                new ShowBook(),
        };
    }

    @Override
    public int menu() {
        System.out.println("欢迎"+this.name+"来到图书管理系统");
        System.out.println("******管理员菜单******");
        System.out.println("1 增加图书");
        System.out.println("2 查找图书");
        System.out.println("3 删除图书");
        System.out.println("4 显示图书");
        System.out.println("0 退出系统");
        System.out.println("********************");
        Scanner sc = new Scanner(System.in);
        int choice = sc.nextInt();
        return choice;
    }
}

那我们接下来以显示图书为例,也就是在ShowBook类里面,来给大家实现一下具体的功能~

package operation;
import BookShelf.Book;
import BookShelf.BookList;

public class ShowBook implements IOperation{

    //重写接口中的方法
    public void work(BookList bookList) {
        System.out.println("正在显示图书......");

        int currentSize = bookList.getValidszie();//获取有效书籍的个数
        for (int i = 0; i < currentSize; i++) {
           Book tmp = bookList.getBooks(i);
           System.out.println(tmp);//打印所有书籍
        }
    }

}

那么我们在main方法里面怎么调用呢? 代码如下:

import BookShelf.BookList;
import User.AdminUser;
import User.NormalUser;
import User.User;

import java.util.Scanner;

public class Main {
    public static User login(){
        Scanner sc = new Scanner(System.in);
        System.out.println("Enter your username: ");
        String name = sc.nextLine();

        System.out.println("Enter your identity: 1->AdminUser 2->NormalUser");
        int choice = sc.nextInt();


        if(choice == 1){
            return new AdminUser(name);
        }else if(choice == 2){
            return new NormalUser(name);
        }
    }

    public static void main(String[] args) {
        BookList bookList = new BookList();
        User user = login();
        while(true){
            int choice = user.menu();
            if(choice == 0){
                System.out.println("退出系统......");
                break;
            }else{
                user.doOperations(choice,bookList);
            }
        }
    }
}

之后我们就实现其它具体功能就好啦~

ExitBook类的具体实现代码如下:

package operation;
import BookShelf.BookList;

public class ExitBook implements IOperation {
    @Override
    public void work(BookList bookList) {
        System.out.println("Exit BookSystem");
        int currentSize = bookList.getValidszie();
        for (int i = 0; i < currentSize; i++) {
            bookList.setBooks(i,null);
        }
        bookList.setValidSzie(0);
        System.exit(0);
    }
}

FindBook类的具体实现代码如下:

package operation;
import BookShelf.Book;
import BookShelf.BookList;
import java.util.Scanner;

public class FindBook implements IOperation {
    public void work(BookList bookList){
        System.out.println("正在查找图书......");
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入你要查找的书籍名称");
        String bookName = scanner.nextLine();

        int currentSize = bookList.getValidszie();
        for (int i = 0; i < currentSize; i++) {
            Book book = bookList.getBooks(i);
            if (book.getName().equals(bookName)) {
                System.out.println("找到了这本书,书籍信息如下所示");
                System.out.println(book);
                return;
            }
        }
        System.out.println("没有此书");
    }
}

AddBook类具体实现功能如下:

package operation;

import BookShelf.Book;
import BookShelf.BookList;

import java.util.Scanner;

public class AddBook implements IOperation {
    public void work(BookList bookList){
        System.out.println("正在增加图书......");

        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入书的名称");
        String bookName = scanner.nextLine();
        System.out.println("请输入作者的名称");
        String author = scanner.nextLine();
        System.out.println("请输入书的类型");
        String type = scanner.nextLine();
        System.out.println("请输入书的价格");
        int price = scanner.nextInt();
        Book book = new Book(bookName, author, type, price);

        int currentSize = bookList.getValidszie();
        for (int i = 0; i < currentSize; i++) {
            if(bookList.getBooks(i).getName().equals(bookName)){
                System.out.println("存在此书,请勿重复添加");
                return;
            }
        }
        bookList.setBooks(currentSize,book);
        bookList.setValidSzie(currentSize+1);
    }

    private boolean isFull(BookList bookList){
        return bookList.getBooks().length == bookList.getValidszie();
    }
}

DeleteBook类具体实现功能如下:

package operation;

import BookShelf.Book;
import BookShelf.BookList;

import java.util.Scanner;

public class DeleteBook implements IOperation {
    public void work(BookList bookList){
        System.out.println("正在删除图书......");
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入你要删除图书的名称");
        String bookName = scanner.nextLine();

        int currentSize = bookList.getValidszie();
        int index = -1;
        int i = 0;
        for (i = 0; i < currentSize; i++) {
            Book tmp = bookList.getBooks(i);
            if(bookList.getBooks(i).getName().equals(bookName)){
                index = i;
                break;
            }
        }
        if(index < 0){
            System.out.println("没有此书");
            return;
        }
        for (int j = index; j < currentSize-1; j++) {
            Book tmp = bookList.getBooks(j+1);
            bookList.setBooks(j,tmp);
        }
        bookList.setValidSzie(currentSize-1);
        bookList.setBooks(currentSize-1,null);
        System.out.println("已删除图书");
    }
}

BorrowBook类具体实现功能如下:

package operation;
import BookShelf.Book;
import BookShelf.BookList;
import java.util.Scanner;

public class BorrowBook implements IOperation {
    public void work(BookList bookList){
        System.out.println("开始借阅图书");
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入你要借阅的图书");
        String bookName = scanner.nextLine();

        int currentSize = bookList.getValidszie();
        for (int i = 0; i < currentSize; i++) {
            if(bookList.getBooks(i).getName().equals(bookName)){
                Book book = bookList.getBooks(i);
                if(book.isborrowed()){
                    System.out.println("此书已被借走");
                }else{
                    book.setborrowed(true);
                    System.out.println(book);
                    System.out.println("借阅成功");
                }
                return;
            }
        }
        System.out.println("未找到此书");
    }
}

ReturnBook类具体实现功能如下:

package operation;
import BookShelf.Book;
import BookShelf.BookList;
import java.util.Scanner;

public class ReturnBook implements IOperation{
    @Override
    public void work(BookList bookList) {
        System.out.println("开始归还图书");
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入你要归还的图书");
        String bookName = scanner.nextLine();

        int currentSize = bookList.getValidszie();
        for (int i = 0; i < currentSize; i++) {
            if(bookList.getBooks(i).getName().equals(bookName)){
                Book book = bookList.getBooks(i);
                if(!book.isborrowed()){
                    System.out.println("此书未被借出");
                }else{
                    book.setborrowed(false);
                    System.out.println(book);
                    System.out.println("归还成功");
                }
                return;
            }
        }
        System.out.println("未找到此书");
    }

}

之后我们就写完了一个简易版的图书管理系统啦~


由于这篇博客带有讲解,也包含了全部代码,但是怕有些小伙伴混乱,所以所有代码放到下篇博客汇总

大家加油!拜拜~

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

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

相关文章

网络安全在现代企业中的重要作用

网络安全是这个数字时代最令人担忧的事情之一。对技术的依赖性越来越强&#xff0c;使其同时面临多种网络威胁。其声誉和法律后果的大幅下降可能归因于一次妥协。 这使得良好的网络安全成为所有企业的选择和必需品。本文介绍了网络安全的重要性、企业中常见的网络威胁以及公司…

Zero to JupyterHub with Kubernetes中篇 - Kubernetes 常规使用记录

前言&#xff1a;纯个人记录使用。 搭建 Zero to JupyterHub with Kubernetes 上篇 - Kubernetes 离线二进制部署。搭建 Zero to JupyterHub with Kubernetes 中篇 - Kubernetes 常规使用记录。搭建 Zero to JupyterHub with Kubernetes 下篇 - Jupyterhub on k8s。 参考&…

三维天地助力生产制造企业做好产品质量控制

生产制造业已成为全球经济的重要支柱,随着全球化的深入发展,生产制造业的竞争愈发激烈。在生产过程中难以避免的质量波动可能导致产品不良率上升,影响客户满意度和企业声誉。为确保产品质量是受控且优质的,确保生产过程的稳定性,大多数生产制造企业都在进行精细化管理改革,依靠…

IC数字后端实现之大厂IC笔试真题(经典时序计算和时序分析题)

今天小编给大家分享下每年IC秋招春招必考题目——静态时序分析时序分析题。 数字IC后端笔试面试题库 | 经典时序Timing计算题 时序分析题1&#xff1a; 给定如下图所示的timing report&#xff0c;请回答一下几个问题。 1&#xff09;这是一条setup还是hold的timing report?…

arcgis for js FeatureLayer和GeoJSON一个矢量点同时渲染图形和文本

效果 FeatureLayer和GeoJSONLayer, 一个矢量点同时渲染图形和文本 代码 相关参数自行查阅文档, 这里就不做注释了 示例代码手动创建FeatureLayer方式, 如果是通过远程url加载图层的 渲染方式同理, GeoJSONLayer同理 <!DOCTYPE html> <html lang"zn"><…

单片机将图片数组调出来显示MPU8_8bpp_Memory_Write

界面显示图片是很常见的需求&#xff0c;使用外挂的FLASH是最常用的方法。但是如果图片需求不大&#xff0c;比如说我们只要显示一个小图标&#xff0c;那么为了节省硬件成本&#xff0c;是不需要外挂一颗FLASH芯片的&#xff0c;我们可以将图标转成数组&#xff0c;存在单片机…

Linux八股积累与笔记

1、iptables 是一个用于配置Linux内核防火墙规则的工具。四表五链&#xff1a;在iptables中&#xff0c;有四个表&#xff08;tables&#xff09;和五个链&#xff08;chains&#xff09;&#xff0c;用于管理不同类型的数据包过滤规则。如下&#xff1a; 表&#xff08;Tabl…

51c自动驾驶~合集38

我自己的原文哦~ https://blog.51cto.com/whaosoft/12358456 #GaussianPretrain 万能3D高斯预训练表示&#xff01;爆拉3D检测、Occ、高精地图等四大任务&#xff01; 受Tesla的技术的推动&#xff0c;越来越多的厂商开始走"纯视觉"的路线&#xff0c;多数方案还…

STM32笔记(串口IAP升级)

一、IAP简介 IAP&#xff08;In Application Programming&#xff09;即在应用编程&#xff0c; IAP 是用户自己的程序在运行过程中对 User Flash 的部分区域进行烧写&#xff0c;目的是为了在产品发布后可以方便地通过预留的通信口对产 品中的固件程序进行更新升级。 通常实…

VsCode 插件推荐(个人常用)

VsCode 插件推荐&#xff08;个人常用&#xff09;

解决`-bash: ./configure:/bin/sh^M:解释器错误: 没有那个文件或目录`的问题

解决`-bash: ./configure:/bin/sh^M:解释器错误: 没有那个文件或目录`的问题 一、错误原因分析二、解决方法方法一:使用`dos2unix`工具方法二:使用`sed`命令方法三:使用`tr`命令方法四:在文本编辑器中转换方法五:在Windows系统中使用适当的工具三、预防措施四、总结在使…

Excel如何设置超出单元格的内容不显示?

如图&#xff0c;在使用EXCEL时经常出现超出单元格显示的情况&#xff1a; 如果想要把超出单元格的部分隐藏&#xff0c;需要进行以下设置&#xff1a; 选中想要设置的单元格&#xff0c;然后点击对齐方式右边的按钮&#xff0c;对齐设置&#xff0c;选择“对齐”选项卡&#…

【干货分享】Boosting算法简单案例

Boosting算法是一种集成学习方法&#xff0c;通过逐步迭代训练弱分类器&#xff0c;并通过加权组合它们的预测结果来构建一个强分类器。 下面是Boosting算法&#xff08;以AdaBoost为例&#xff09;的详细过程和一个案例&#xff1a; 1. 数据准备&#xff1a;首先&#xff0c;将…

如何搭建高效的实时美颜直播APP?美颜SDK与美颜API的开发详

时下&#xff0c;搭建一款高效的实时美颜直播APP&#xff0c;尤其是集成美颜SDK与美颜API&#xff0c;已成为开发者们的技术难题。本篇文章&#xff0c;小编将详细探讨如何利用美颜SDK与美颜API来搭建一款高效的实时美颜直播APP&#xff0c;提升产品的竞争力。 一、实时美颜技…

Spring Boot教程之十一:获取Request 请求 和 Put请求

如何在 Spring Boot 中获取Request Body&#xff1f; Java 语言是所有编程语言中最流行的语言之一。使用 Java 编程语言有几个优点&#xff0c;无论是出于安全目的还是构建大型分发项目。使用 Java 的优点之一是 Java 试图借助类、继承、多态等概念将语言中的每个概念与现实世…

【JAVA进阶篇教学】第二十篇:如何高效处理List集合数据及明细数据

博主打算从0-1讲解下java进阶篇教学&#xff0c;今天教学第二十篇&#xff1a;如何高效处理List集合数据及明细数据。 Java 8 Stream API 助力高效处理集合数据&#xff08;订单明细查询优化案例&#xff09; 目录 一、前言 二、问题回顾 三、优化思路与 Stream API 的运用…

Linux的介绍及虚拟机centOS系统的下载与应用

1、什么是Linux Linux 是一种类 Unix 操作系统&#xff0c;它的内核&#xff08;Kernel&#xff09;由 Linus Torvalds 于 1991 年首次发布。作为一个开源、免费的操作系统&#xff0c;Linux 被广泛用于服务器、桌面计算机、嵌入式设备、移动设备等各种场景。 1、操作系统 操…

ORACLE数据库直接取出数据库字段JSON串中的 VALUE内容

字段内容类似这种&#xff1a; 如果是12c以上版本可以使用 SELECT JSON_VALUE(MEMO, $.supplyExercisePrice) AS supplyExercisePrice FROM your_table;如果是11g版本可以使用 SELECT REGEXP_SUBSTR(MEMO, "supplyExercisePrice":"([^"])", 1, 1, …

业务分组:流量隔离

RPC中常用的保护手段“熔断限流”&#xff0c;熔断是调用方为了避免在调用过程中&#xff0c;服务提供方出现问题的时候&#xff0c;自身资源被耗尽的一种保护行为&#xff1b;而限流则是服务提供方为防止自己被突发流量打垮的一种保护行为。虽然这两种手段作用的对象不同&…

数据结构——排序算法第二幕(交换排序:冒泡排序、快速排序(三种版本) 归并排序:归并排序(分治))超详细!!!!

文章目录 前言一、交换排序1.1 冒泡排序1.2 快速排序1.2.1 hoare版本 快排1.2.2 挖坑法 快排1.2.3 lomuto前后指针 快排 二、归并排序总结 前言 继上篇学习了排序的前面两个部分:直接插入排序和选择排序 今天我们来学习排序中常用的交换排序以及非常稳定的归并排序 快排可是有多…