当前位置: 首页 > news >正文

基于C语言实现的图书管理系统

使用Visual Studio 2022编译工具进行编写代码的。

项目源码直接奉上:

book1.h头文件:

#ifndef __BOOK1_H  //预处理用于条件编译 避免头文件反复包含
#define __BOOK1_H#include<stdio.h>
#include <string.h>
#include<stdlib.h>
#include<stdbool.h>
#include<time.h>//显示当前时间#define MAX_BOOK 1000
#define MAX_BOOK1 100 //每个编号图书数量的最大限制
#define MAX_STUBOOK 10 //读者借书的最大限制//图书信息
typedef struct book_str {unsigned int ID; //图书编号char name[MAX_BOOK1]; //图书名字char anthor[MAX_BOOK1];//作者unsigned int price; //单本书价格unsigned int num; //图书数量char location[MAX_BOOK1]; //图书位置
}BOOK;typedef struct book_str1 {struct book_str book;struct book_str1* next;
}BookList;//登录信息
typedef struct stu {char name[MAX_BOOK1]; //用户名char password[20]; //密码 unsigned long int phone;//电话
}USER;typedef struct stu1 {USER st;struct stu1* next;
}UserLog;//图书借阅
typedef struct book_borr
{char stuname[MAX_BOOK1]; //学生姓名unsigned int ID;  //图书IDchar name[MAX_BOOK1]; //图书名字char state[MAX_BOOK1];//借书的状态char time[MAX_BOOK1];  //time 保存20个字节就可以了int num;//允许借书的最大值}Borrow;typedef struct book_borr1
{struct book_borr data_book;struct book_borr1* next;
}BorrowList;void fun();
void fun1();
void fun2();
//创建图书借阅的链表
BorrowList* init_borrow();
//尾插法--插入原始数据
bool tail_borrow(BorrowList* head, char stuname[MAX_BOOK1], unsigned int ID, char name[MAX_BOOK1], char state[MAX_BOOK1], char time[MAX_BOOK1]);
//用户记录--借阅信息
//尾插法
bool tail_borrow1(BorrowList* head, BookList* head1,  char stuname[MAX_BOOK1],unsigned int ID, char name[MAX_BOOK1]);
//找到借阅的人
bool find_borrow(BorrowList* head, char stuname[MAX_BOOK1]);
//用户归还图书
bool del_borrow1(BorrowList* head, BookList* head1, char stuname[MAX_BOOK1], unsigned int ID, char name[MAX_BOOK1]);
//遍历链表
void print_borrow(BorrowList* head);
//回收链表
void free_borrow(BorrowList* head);//创建图书链表
BookList* init_book();
//尾插法
bool tail_book(BookList* head);
//按编号进行排序
void sort_book(BookList* head);
//删除图书
bool del_book(BookList* head, unsigned int ID);
//删除一本图书
bool del_book1(BookList* head, unsigned int ID);
//查询图书---按编号查找
bool find_book(BookList* head, unsigned int ID);
//查询图书---按书名查找
bool find_bookname(BookList* head, char name[MAX_BOOK1]);
//查询图书---按作者查找
bool find_anthorname(BookList* head, char anthor[MAX_BOOK1]);
//修改数据
bool rework_book(BookList* head, unsigned int ID, unsigned int sum);
//向链表中插入原始数据
bool tail_book1(BookList* head, unsigned int ID, char name[MAX_BOOK1], char anthor[MAX_BOOK1], unsigned int price, unsigned int num);
//链表长度
int length_book(BookList* head);
//遍历
void print_book(BookList* head);
//回收链表
void free_book(BookList* head);
//int count;
//写文件--将文件中的信息写入到链表中 图书信息
void file_readbook(BookList* head);
//写文件--将链表中的信息写到文件中 图书信息
void file_savebook(BookList* head);
//学生借阅信息表--从链表写入到文件
void file_savestubook(BorrowList* head);
//学生借阅信息表--从文件写入到链表
void file_readstuook(BorrowList* head);
//写文件--将文件中的信息写入到链表中 图书信息
void file_readbook1(BookList* head);
//写文件--将链表中的信息写到文件中 图书信息
void file_savebook1(BookList* head);
//用户登录信息表--从链表写入到文件
void file_saveuser(UserLog* head);
//用户登录信息表--从文件写入到链表
void file_readuser(UserLog* head);//图书信息查找---按编号,书名,作者
bool book_find(BookList* head);//创建用户的链表
UserLog* init_user();
//插入用户账号信息
bool tail_user(UserLog* head, char user[MAX_BOOK1], char password[20], unsigned long int phone);
//注册用户
bool register_user(UserLog* head);
//找到某个用户信息
bool find_user(UserLog* head, char name[MAX_BOOK1]);
//修改用户个人信息
bool rework_user(UserLog* head, char name[MAX_BOOK1]);
//遍历用户链表
void print_user(UserLog* head);
//回收链表
void free_user(UserLog* head);//管理员登录
void admin_log();
//登录操作
bool user_log(UserLog* head);
//用户登录
void student_log(char stuanme[MAX_BOOK1]);#endif
#pragma once

main.c 文件: 

#include "book1.h"//提示页面 
void fun()
{printf("----------------------------------------------------------------------------------\n");printf("=                                  欢迎使用图书管理软件                          =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                    请选择功能                                  =\n");printf("=                                    0.退出系统                                  =\n");printf("=                                    1.用户登录                                  =\n");printf("=                                    2.用户注册                                  =\n");printf("----------------------------------------------------------------------------------\n");}void fun1()
{printf("----------------------------------------------------------------------------------\n");printf("=                                     管理员登录                                 =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                     0.退出系统                                 =\n");printf("=            1.图书汇总表                                  2.添加书籍            =\n");printf("=            3.删除书籍                                    4.查找书籍            =\n");printf("=            5.修改图书                                    6.图书借阅            =\n");printf("=            7.查看用户信息                                8.图书库存            =\n");printf("----------------------------------------------------------------------------------\n");
}void fun2()
{printf("----------------------------------------------------------------------------------\n");printf("=                                     用户登录                                   =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                     0.退出系统                                 =\n");printf("=            1.图书借阅                                  2.图书归还              =\n");printf("=            3.图书查阅                                  4.信息修改              =\n");printf("----------------------------------------------------------------------------------\n");
}//创建用户的链表
UserLog* init_user()
{UserLog* head = (UserLog*)malloc(sizeof(UserLog));if (head == NULL){printf("当前没有用户,请先创建\n");return NULL;}head->next = NULL;return head;
}
//插入用户账号信息
bool tail_user(UserLog* head, char user[MAX_BOOK1], char password[20], unsigned long int phone)
{bool find_flag = false;UserLog* new_node = (UserLog*)malloc(sizeof(UserLog));if (new_node == NULL) return false;strcpy_s(new_node->st.name,MAX_BOOK1, user);strcpy_s(new_node->st.password, 20,password);new_node->st.phone = phone;new_node->next = NULL;UserLog* p = head;while (p != NULL){if (p->next == NULL){find_flag = true;break;}p = p->next;}if (find_flag == false){printf("插入失败,该用户已存在,请登录!\n");}p->next = new_node;return true;
}//注册用户
bool register_user(UserLog* head)
{bool find_flag = false;UserLog* new_node = (UserLog*)malloc(sizeof(UserLog));if (new_node == NULL)return false;printf("请依次输入账号, 密码, 电话:");scanf_s("%s", new_node->st.name,MAX_BOOK1);scanf_s("%s", new_node->st.password, 20);scanf_s("%ld", &new_node->st.phone);new_node->next = NULL;UserLog* p = head;while (p != NULL){if (strcmp(p->st.name,new_node->st.name) == 0){find_flag = false;break;}if (p->next == NULL){find_flag = true;break;}p = p->next;}if (find_flag == false){printf("库中已有该账号,添加失败!!!\n");return false;}else{printf("已成功添加!!!\n");p->next = new_node;}return true;
}
//找到某个用户信息
bool find_user(UserLog* head, char name[MAX_BOOK1])
{bool find_flag = false;UserLog* p = head->next;if (p == NULL) return false;printf("\n-----------------------------------------------------\n");printf("\n=====================用户信息表======================\n");printf("%-15s %-15s %-15s\n", "账号", "密码", "电话");while (p != NULL){if (strcmp(p->st.name, name) == 0){find_flag = true;printf("%-15s %-15s %-15ld\n", p->st.name, p->st.password, p->st.phone);}p = p->next;}if (find_flag == false){printf("没找到该用户\n");}return true;
}
//修改用户个人信息
bool rework_user(UserLog* head,char name[MAX_BOOK1])
{UserLog* p = head->next;if (p == NULL) return false;printf("\n-----------------------------------------------------\n");printf("\n=====================用户信息表======================\n");printf("%-15s %-15s %-15s\n", "账号", "密码", "电话");while (p != NULL){if (strcmp(p->st.name, name) == 0){printf("%-15s %-15s %-15ld\n", p->st.name, p->st.password, p->st.phone);printf("----------------------------------------------------------------------------------\n");printf("=                                请选择要修改的信息                              =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                  0.退出修改                                    =\n");printf("=                 1.修改账号名称                 2.修改密码                      =\n");printf("=                                 3.修改手机号                                   =\n");printf("----------------------------------------------------------------------------------\n");while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:fun2();return false;case 1:{char stuname[MAX_BOOK1];printf("请输入要修改的名称:");scanf_s("%s", stuname, MAX_BOOK1);strcpy(p->st.name, stuname);printf("\n-----------------------------------------------------\n");printf("\n=====================用户信息表======================\n");printf("%-15s %-15s %-15ld\n", p->st.name, p->st.password, p->st.phone);}break;case 2:{char password[20];printf("请输入要修改的密码:");scanf_s("%s", password, 20);strcpy(p->st.password,password);printf("\n-----------------------------------------------------\n");printf("\n=====================用户信息表======================\n");printf("%-15s %-15s %-15ld\n", p->st.name, p->st.password, p->st.phone);break;}case 3:{unsigned int phone;printf("请输入要修改的电话:");scanf_s("%d", &phone);p->st.phone = phone;printf("\n-----------------------------------------------------\n");printf("\n=====================用户信息表======================\n");printf("%-15s %-15s %-15ld\n", p->st.name, p->st.password, p->st.phone);break;}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}}p = p->next;}return true;
}
//遍历用户链表
void print_user(UserLog* head)
{UserLog* p = head->next;if (p == NULL)return;printf("\n-----------------------------------------------------\n");printf("\n=====================用户信息表======================\n");printf("%-15s %-15s %-15s\n", "账号", "密码","电话");while (p != NULL){printf("%-15s %-15s %-15ld\n", p->st.name,p->st.password,p->st.phone);p = p->next;}
}
//回收链表
void free_user(UserLog* head)
{UserLog* p = head->next, * q = p;if (p == NULL)return;while (p != NULL){q = p->next;free(p);p = q;}
}//创建图书借阅的链表
BorrowList* init_borrow()
{BorrowList* head = (BorrowList*)malloc(sizeof(BorrowList));if (head == NULL){printf("当前没有书籍,请先创建\n");return NULL;}head->next = NULL;return head;
}
//尾插法--插入原始数据
bool tail_borrow(BorrowList* head, char stuname[MAX_BOOK1],unsigned int ID, char name[MAX_BOOK1], char state[MAX_BOOK1], char time[MAX_BOOK1])
{bool find_flag = false;BorrowList* new_node = (BorrowList*)malloc(sizeof(BorrowList));if (new_node == NULL) return false;strcpy_s(new_node->data_book.stuname, MAX_BOOK1, stuname);new_node->data_book.ID = ID;strcpy_s(new_node->data_book.name, MAX_BOOK1, name);strcpy_s(new_node->data_book.state, MAX_BOOK1, state);strcpy_s(new_node->data_book.time,MAX_BOOK1,time);new_node->next = NULL;BorrowList* p = head;while (p != NULL){if (p->next == NULL){find_flag = true;break;}p = p->next;}if (find_flag == false){printf("插入失败!\n");}p->next = new_node;return true;
}//用户记录--借阅信息
//尾插法
bool tail_borrow1( BorrowList* head, BookList* head1,char stuname[MAX_BOOK1], unsigned int ID, char name[MAX_BOOK1])
{// 获取当前时间的秒数time_t currentTime = time(NULL);// 将秒数转换为本地时间的结构体struct tm* localTime = localtime(&currentTime);// 格式化本地时间为字符串char timeString[MAX_BOOK1];strftime(timeString, sizeof(timeString), "%Y%m%d %H:%M:%S", localTime);// 输出当前时间printf("\n当前时间:%s\n", timeString);bool find_flag = false;BorrowList* new_node = (BorrowList*)malloc(sizeof(BorrowList));if (new_node == NULL)return false;//printf("请依次输入借阅人,图书ID,图书名称:");//scanf_s("%s", &new_node->data_book.stuname, MAX_BOOK1);//scanf_s("%d", &new_node->data_book.ID);//scanf_s("%s", new_node->data_book.name, MAX_BOOK1);strcpy_s(new_node->data_book.stuname, MAX_BOOK1, stuname);  //学生名字new_node->data_book.ID = ID;//图书编号strcpy_s(new_node->data_book.name, MAX_BOOK1, name);  //书名strcpy_s(new_node->data_book.time, MAX_BOOK1, timeString);  //当前时间strcpy_s(new_node->data_book.state, MAX_BOOK1, "已借阅");new_node->next = NULL;BookList* q = head1;while (q != NULL){if ((q->book.ID == new_node->data_book.ID) && (q->book.num > 0)) //用来判断用户所借书的ID与现有图书的ID是否相等以及该编号的图书是否还有库存{q->book.num--; //现有图书数量就会减少一本find_flag = true;break;}q = q->next;}if (find_flag == false){printf("登记失败,没有该编号的图书!!!\n");return false;}BorrowList* p = head;p->data_book.num = 0;while (p != NULL){if (strcmp(p->data_book.stuname, new_node->data_book.stuname) == 0 && strcmp(p->data_book.state,"已借阅")){printf("借书数量:%d\n", p->data_book.num);if (p->data_book.num > MAX_STUBOOK) //判断读者借的图书是否超过限制{find_flag = false;printf("借书超过限制!!!\n");break;}p->data_book.num++;}//否则就将用户的借阅信息利用尾插法记入else if (p->next == NULL){//num++;find_flag = true;p->next = new_node;break;}p = p->next;}return true;
}//找到借阅的人
bool find_borrow(BorrowList* head, char stuname[MAX_BOOK1])
{bool find_flag = false;BorrowList* p = head->next;if (p == NULL) return false;printf("\n---------------------------------------------------------------------------\n");printf("\n============================图书借阅表=====================================\n");printf("%-10s %-15s %-15s %-15s %-15s\n", "借阅人", "图书编号", "借阅状态", "图书名字", "借阅日期");while (p != NULL){if ((strcmp(p->data_book.stuname, stuname) == 0)){find_flag = true;printf("%-10s %-15d %-15s %-15s %s\n", p->data_book.stuname, p->data_book.ID, p->data_book.name, p->data_book.state, p->data_book.time);//break;}p = p->next;}return true;
}//查找已借阅人的信息
bool find_borrow1(BorrowList* head)
{bool find_flag = false;BorrowList* p = head->next;if (p == NULL) return false;printf("\n---------------------------------------------------------------------------\n");printf("\n============================图书借阅表=====================================\n");printf("%-10s %-15s %-15s %-15s %-15s\n", "借阅人", "图书编号", "借阅状态", "图书名字", "借阅日期");while (p != NULL){if ((strcmp(p->data_book.state, "已借阅") == 0)){find_flag = true;printf("%-10s %-15d %-15s %-15s %s\n", p->data_book.stuname, p->data_book.ID, p->data_book.name, p->data_book.state, p->data_book.time);//break;}p = p->next;}return true;
}
//查找已归还人的信息
bool find_borrow2(BorrowList* head)
{bool find_flag = false;BorrowList* p = head->next;if (p == NULL) return false;printf("\n---------------------------------------------------------------------------\n");printf("\n============================图书借阅表=====================================\n");printf("%-10s %-15s %-15s %-15s %-15s\n", "借阅人", "图书编号", "借阅状态", "图书名字", "借阅日期");while (p != NULL){if ((strcmp(p->data_book.state, "已归还") == 0)){find_flag = true;printf("%-10s %-15d %-15s %-15s %s\n", p->data_book.stuname, p->data_book.ID, p->data_book.name, p->data_book.state, p->data_book.time);//break;}p = p->next;}return true;
}//管理员查找借阅的信息
void find_borrowfun(BorrowList *head)
{printf("----------------------------------------------------------------------------------\n");printf("=                                请选择要查阅的信息                              =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                  0.退出查阅                                    =\n");printf("=                 1.查找借阅人                 2.查找已借阅的人                  =\n");printf("=                                3.查找已归还的人                                =\n");printf("----------------------------------------------------------------------------------\n");while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:fun1();return;case 1:{char stuname[MAX_BOOK1];printf("请输入要查找的借阅人:");scanf_s("%s", stuname, MAX_BOOK1);find_borrow(head, stuname);}break;case 2:{find_borrow1(head);break;}case 3:{find_borrow2(head);break;}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}
}//用户归还图书
bool del_borrow1(BorrowList* head, BookList* head1, char stuname[MAX_BOOK1], unsigned int ID, char name[MAX_BOOK1])
{bool find_flag = false;// 获取当前时间的秒数time_t currentTime = time(NULL);// 将秒数转换为本地时间的结构体struct tm* localTime = localtime(&currentTime);// 格式化本地时间为字符串char timeString[MAX_BOOK1];strftime(timeString, sizeof(timeString), "%Y%m%d %H:%M:%S", localTime);BookList* q = head1;while (q != NULL){if ((q->book.ID == ID)){q->book.num++; //还书库存加1find_flag = true;break;}q = q->next;}if (find_flag == false){printf("登记失败,没有该编号的图书!!!\n");return false;}BorrowList* p = head->next;if (p == NULL) return false;while (p != NULL){if ((strcmp(p->data_book.stuname, stuname) == 0) && (p->data_book.ID == ID) && (strcmp(p->data_book.name, name) == 0)){find_flag = true;strcpy_s(p->data_book.time, MAX_BOOK1, timeString);  //当前时间printf("\n----------------------------------------------------------------------------\n");printf("\n============================图书借阅表=====================================\n");printf("%-10s %-15s %-15s %-15s %-15s\n", "借阅人", "图书编号", "图书名字", "借阅状态", "借阅日期");printf("%-10s %-15d %-15s %-15s %s\n", p->data_book.stuname, p->data_book.ID, p->data_book.name, p->data_book.state, p->data_book.time);break;}p = p->next;}if (find_flag == false){printf("未找到该编号的图书\n");return false;}else{printf("已找到!!!\n");strcpy_s(p->data_book.state, MAX_BOOK1, "已归还");}return true;}//遍历链表
void print_borrow(BorrowList* head)
{BorrowList* p = head->next;if (p == NULL) return;printf("\n----------------------------------------------------------------------------\n");printf("\n============================图书借阅表=====================================\n");printf("%-10s %-15s %-15s %-15s %-15s\n", "借阅人", "图书编号", "图书名字", "借阅状态", "借阅日期");while (p != NULL){printf("%-10s %-15d %-15s %-15s %s\n", p->data_book.stuname, p->data_book.ID, p->data_book.name, p->data_book.state, p->data_book.time);p = p->next;}
}//回收链表
void free_borrow(BorrowList* head)
{BorrowList* p = head->next, * q = head;if (p == NULL) return;while (p != NULL){q = p->next;free(p);p = q;}
}//创建图书链表
BookList* init_book()
{BookList* head = (BookList*)malloc(sizeof(BookList));if (head == NULL)return NULL;head->next = NULL;return head;}//尾插法--添加书籍
bool tail_book(BookList* head)
{bool find_flag = false;BookList* new_node = (BookList*)malloc(sizeof(BookList));if (new_node == NULL)return false;printf("请依次输入图书编号,图书名称,图书作者,图书价格/单本元,图书数量,图书位置:");scanf_s("%d", &new_node->book.ID);scanf_s("%s", new_node->book.name, MAX_BOOK1);scanf_s("%s", new_node->book.anthor, MAX_BOOK1);scanf_s("%d", &new_node->book.price);scanf_s("%d", &new_node->book.num);scanf_s("%s", new_node->book.location, MAX_BOOK1);new_node->next = NULL;BookList* p = head;while (p != NULL){if ((p->book.ID == new_node->book.ID)){find_flag = false;break;}if (p->next == NULL){find_flag = true;break;}p = p->next;}if (find_flag == false){printf("库中已有该编号的图书,添加失败!!!\n");find_book(head, new_node->book.ID);//fun1();return false;}else{printf("已成功添加!!!\n");p->next = new_node;sort_book(head);print_book(head);}//p->book.num++;return true;
}//按编号进行排序
void sort_book(BookList* head)
{int size = length_book(head);BookList* p = head->next;for (int i = 0; i < size - 1; i++){p = head->next;for (int j = 0; j < size - i - 1; j++, p = p->next){if (p->book.ID > p->next->book.ID){struct book_str temp = p->book;p->book = p->next->book;p->next->book = temp;}}}
}//删除图书
bool del_book(BookList* head, unsigned int ID)
{bool find_flag = false;BookList* p = head->next, * q = head;if (p == NULL || head == NULL)return false;while (p != NULL){if (p->book.ID == ID){find_flag = true;break;}p = p->next;q = q->next;}if (find_flag == false){printf("未找到该编号的图书\n");fun1();return false;}else{printf("已找到该图书\n");find_book(head, ID);printf("----------------------------------------------------------------------------------\n");printf("=                              请选择要删除图书的信息                            =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                  0.无需删除                                    =\n");printf("=                 1.删除该书所有                 2.仅删除一本                    =\n");printf("----------------------------------------------------------------------------------\n");while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:printf("退出删除操作\n");fun1();return false;case 1:{q->next = p->next;free(p);printf("已删除!!!\n");printf("删除后:\n");print_book(head);break;}case 2:{p->book.num--;//q->next = p->next;//free(p);printf("已删除!!!\n");printf("删除后:\n");print_book(head);break;}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}}return true;
}//删除一本图书
bool del_book1(BookList* head, unsigned int ID)
{bool find_flag = false;BookList* p = head->next, * q = head;if (p == NULL || head == NULL)return false;//int num = length_book(head);while (p != NULL){if (p->book.ID == ID){find_flag = true;break;}p = p->next;q = q->next;}if (find_flag == false){printf("未找到该编号的图书\n");return false;}p->book.num--;//q->next = p->next;//free(p);printf("已删除!!!");return true;
}//查询图书---按编号查找
bool find_book(BookList* head, unsigned int ID)
{bool find_flag = false;BookList* p = head->next;if (p == NULL) return false;while (p != NULL){if (p->book.ID == ID){find_flag = true;//printf("%d", p->book.ID);printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量","图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num,p->book.location);break;}p = p->next;}if (find_flag == false){printf("未找到该编号的图书\n");return false;}else{printf("已找到!!!\n");}return true;
}//查询图书---按书名查找
bool find_bookname(BookList* head, char name[MAX_BOOK1])
{bool find_flag = false;BookList* p = head->next;if (p == NULL) return false;while (p != NULL){if (strcmp(p->book.name, name) == 0){find_flag = true;//printf("%d", p->book.ID);printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);break;}p = p->next;}if (find_flag == false){printf("未找到该编号的图书\n");return false;}else{printf("已找到!!!\n");}return true;
}//查询图书---按作者查
bool find_anthorname(BookList* head, char anthor[MAX_BOOK1])
{bool find_flag = false;BookList* p = head->next;if (p == NULL) return false;while (p != NULL){if (strcmp(p->book.anthor, anthor) == 0){find_flag = true;//printf("%d", p->book.ID);printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);break;}p = p->next;}if (find_flag == false){printf("未找到该编号的图书\n");return false;}else{printf("已找到!!!\n");}return true;
}//修改数据
bool rework_book(BookList* head)
{bool find_flag = false;BookList* p = head->next;if (p == NULL) return false;unsigned int sum = 0;if (sum > MAX_BOOK1)  //每个编号图书的数量不能大于MAX_BOOK1(100){printf("修改的值超出限制!!!\n");return false;}unsigned int ID = 0;printf("请输入要修改的图书ID:");scanf_s("%d", &ID);while (p != NULL){if (p->book.ID == ID){printf("已找到:\n");printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);printf("----------------------------------------------------------------------------------\n");printf("=                                请选择要修改的信息                              =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                  0.退出修改                                    =\n");printf("=                 1.修改图书名称                 2.修改作者                      =\n");printf("=                 3.修改图书数量                 4.修改图书价格                  =\n");printf("=                                 5.修改图书位置                                 =\n");printf("----------------------------------------------------------------------------------\n");find_flag = true;//printf("%d", p->book.ID);while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:fun1();return false;case 1:{char name[MAX_BOOK1];printf("请输入要修改的图书名称:");scanf_s("%s", name, MAX_BOOK1);strcpy(p->book.name, name);printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);}break;case 2:{char anthor[MAX_BOOK1];printf("请输入要修改的作者:");scanf_s("%s",anthor, MAX_BOOK1);strcpy(p->book.anthor,anthor);printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);break;}case 3:{unsigned int num;printf("请输入要修改的图书数量:");scanf_s("%d", &num);p->book.num = num;printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);break;}case 4:{unsigned int price;printf("请输入要修改的图书价格:");scanf_s("%d", &price);p->book.price = price;printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);break;}case 5:{char location[MAX_BOOK1];printf("请输入要修改的图书位置:");scanf_s("%s",location,MAX_BOOK1);strcpy(p->book.location, location);printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}break;}p = p->next;}if (find_flag == false){printf("未找到该编号的图书\n");return false;}else{p->book.num = sum;printf("修改后:\n");printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);}return true;}//向链表中插入原始数据
bool tail_book1(BookList* head, unsigned int ID, char name[MAX_BOOK1],char anthor[MAX_BOOK1],unsigned int price, unsigned int num,char location[MAX_BOOK1])
{BookList* new_node = (BookList*)malloc(sizeof(BookList));if (new_node == NULL)return false;//printf("请依次输入图书编号,图书名称, 图书作者, 图书价格/单本, 图书数量:");new_node->book.ID = ID;strcpy_s(new_node->book.name, MAX_BOOK1, name);strcpy_s(new_node->book.anthor, MAX_BOOK1, anthor);new_node->book.price = price;new_node->book.num = num;strcpy_s(new_node->book.location, MAX_BOOK1, location);new_node->next = NULL;BookList* p = head;if (p == NULL)return false;while (p != NULL){if (p->next == NULL)break;p = p->next;}p->next = new_node;return true;
}//链表长度
int length_book(BookList* head)
{int count = 0;BookList* p = head->next;if (p == NULL) return false;while (p != NULL){count++;p = p->next;}return count;
}//遍历
void print_book(BookList* head)
{BookList* p = head->next;if (p == NULL)return;printf("\n---------------------------------------------------------------------------------------------\n");printf("\n=======================================图书信息表============================================\n");printf("%-10s %-15s %-15s %-15s %-15s %-15s\n", "图书编号", "图书名字", "图书作者", "图书价格/单本元", "图书数量", "图书位置");while (p != NULL){printf("%-10d %-15s %-15s %-15d %-15d %-15s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);p = p->next;}
}//回收链表
void free_book(BookList* head)
{BookList* p = head->next, * q = p;if (p == NULL)return;while (p != NULL){q = p->next;free(p);p = q;}}//int count;
//写文件--将文件中的信息写入到链表中 图书信息
void file_readbook(BookList* head)
{//打开节点FILE* fd = NULL;fd = fopen("./book1.txt", "r+");if (!fd){printf("文件打开失败\n");return;}BookList* p = head;//if (p != NULL) return;while (1){BookList* new_node = (BookList*)malloc(sizeof(BookList));//if (new_node == NULL) return;fscanf_s(fd, "%d %s %s %d %d %s", &new_node->book.ID, new_node->book.name, MAX_BOOK1,new_node->book.anthor,MAX_BOOK1,&new_node->book.price, &new_node->book.num,new_node->book.location,MAX_BOOK1);new_node->next = NULL;if (feof(fd)){break;}else if (p->next == NULL){p->next = new_node;}p = p->next;}fclose(fd);}//写文件--将链表中的信息写到文件中 图书信息
void file_savebook(BookList* head)
{FILE* fp;fp = fopen("./book1.txt", "w+");if (fp == NULL){printf("文件打开失败\n");return;}//遍历链表BookList* p = head->next;while (p != NULL){fprintf(fp, "%d\t%s\t%s\t%d\t%d\t%s\n", p->book.ID, p->book.name,p->book.anthor,p->book.price, p->book.num,p->book.location);p = p->next;}fclose(fp);}//写文件--将文件中的信息写入到链表中 图书信息
void file_readbook1(BookList* head)
{//打开节点FILE* fd = NULL;fd = fopen("./图书库存.txt", "r+");if (!fd){printf("文件打开失败\n");return;}BookList* p = head;//if (p != NULL) return;while (1){BookList* new_node = (BookList*)malloc(sizeof(BookList));//if (new_node == NULL) return;fscanf_s(fd, "%d %s %s %d %d %s", &new_node->book.ID, new_node->book.name, MAX_BOOK1, new_node->book.anthor, MAX_BOOK1, &new_node->book.price, &new_node->book.num, new_node->book.location, MAX_BOOK1);new_node->next = NULL;if (feof(fd)){break;}else if (p->next == NULL){p->next = new_node;}p = p->next;}fclose(fd);
}//写文件--将链表中的信息写到文件中 图书信息
void file_savebook1(BookList* head)
{FILE* fp;fp = fopen("./图书库存.txt", "w+");if (fp == NULL){printf("文件打开失败\n");return;}//遍历链表BookList* p = head->next;while (p != NULL){fprintf(fp, "%d\t%s\t%s\t%d\t%d\t%s\n", p->book.ID, p->book.name, p->book.anthor, p->book.price, p->book.num, p->book.location);p = p->next;}fclose(fp);}//学生借阅信息表--从链表写入到文件
void file_savestubook(BorrowList* head)
{FILE* fp;fp = fopen("./stubook1.txt", "w+");if (fp == NULL){printf("文件打开失败\n");return;}//遍历链表BorrowList* p = head->next;//遍历链表while (p != NULL){fwrite(&(p->data_book), sizeof(BorrowList), 1, fp);p = p->next;}fclose(fp);}//学生借阅信息表--从文件写入到链表
void file_readstuook(BorrowList* head)
{//打开节点FILE* fd = NULL;fd = fopen("./stubook1.txt", "r+");if (!fd){printf("文件打开失败\n");return;}BorrowList temp;while (fread(&(temp.data_book), sizeof(BorrowList), 1, fd) == 1) //feof函数feof()在到达给出的文件流的文件尾时返回一个非零值. {tail_borrow(head, temp.data_book.stuname, temp.data_book.ID, temp.data_book.name, temp.data_book.state, temp.data_book.time);}fclose(fd);
}//用户登录信息表--从链表写入到文件
void file_saveuser(UserLog* head)
{FILE* fp;fp = fopen("./用户信息.txt", "w+");if (fp == NULL){printf("文件打开失败\n");return;}//遍历链表UserLog* p = head->next;//遍历链表while (p != NULL){fwrite(&(p->st), sizeof(UserLog), 1, fp);p = p->next;}fclose(fp);}//用户登录信息表--从文件写入到链表
void file_readuser(UserLog* head)
{//打开节点FILE* fd = NULL;fd = fopen("./用户信息.txt", "r+");if (!fd){printf("文件打开失败\n");return;}UserLog temp;while (fread(&(temp.st), sizeof(UserLog), 1, fd) == 1) //feof函数feof()在到达给出的文件流的文件尾时返回一个非零值. {tail_user(head, temp.st.name, temp.st.password, temp.st.phone);}fclose(fd);
}//图书查找操作
bool book_find(BookList* head)
{//查找操作printf("----------------------------------------------------------------------------------\n");printf("=                              请选择要查找图书的信息                            =\n");printf("----------------------------------------------------------------------------------\n");printf("=                                  0.返回操作                                    =\n");printf("=                1.按图书编号查找              2.按图书名称查找                  =\n");printf("=                                3.按图书作者查找                                =\n");printf("----------------------------------------------------------------------------------\n");{while (1){int n1 = 0;printf("select>");scanf_s("%d", &n1);switch (n1){case 0:printf("退出查找操作\n");fun1();return false;case 1:{int ID1 = 0;printf("请输入要查询图书的编号:");scanf_s("%d", &ID1);find_book(head, ID1);}break;case 2:{char name[MAX_BOOK1] = { 0 };printf("请输入要查询图书的名称:");scanf_s("%s", name, MAX_BOOK1);find_bookname(head, name);}break;case 3:{char anthor[MAX_BOOK1] = { 0 };printf("请输入要查询作者的名称:");scanf_s("%s", anthor, MAX_BOOK1);find_anthorname(head, anthor);}break;default:printf("您输入的数据无效,请重新输入!!!\n");break;}}}return true;
}//管理员登录
void admin_log()
{BorrowList* head1 = init_borrow();  //图书借阅链表/*tail_borrow(head1, "张三", 1001, "红楼梦", "已借阅", "20240721 12:30:05");tail_borrow(head1, "李四", 1002, "三国演义", "已借阅", "20240721 12:30:05");file_savestubook(head1);*/file_readstuook(head1);//链表中图书借阅原始数据BookList* head = init_book(); //图书链表/*tail_book1(head,1001,"红楼梦","曹雪芹",20,6,"1号架A面");tail_book1(head, 1002, "三国演义", "罗贯中", 22, 4,"1号架B面");tail_book1(head, 1003, "西游记", "吴承恩", 55, 9,"1号架C面");tail_book1(head, 1004, "水浒传", "施耐庵", 34, 2,"1号架D面");file_savebook(head);*/file_readbook(head); //原始数据链表//print_book(head);BookList* head3 = init_book(); //图书库存链表file_readbook1(head3);//登录信息表UserLog* head2 = init_user();file_readuser(head2);while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:printf("退出操作\n");fun();return;case 1://file_read(head);print_book(head);break;case 2:{//增加操作tail_book(head);file_savebook(head);file_savebook1(head);break;}case 3:{//删除操作int ID = 0;printf("请输入要删除图书的编号:");scanf_s("%d", &ID);del_book(head, ID);file_savebook(head);file_savebook1(head);break;}case 4:{//查找操作book_find(head);break;}case 5:{//修改操作rework_book(head);file_savebook(head);file_savebook1(head);break;}case 6:{//查看借阅信息//char stuname[MAX_BOOK1];print_borrow(head1);/*printf("请输入要查询的借阅人信息:");scanf_s("%s", stuname,MAX_BOOK1);find_borrow(head1, stuname);*/find_borrowfun(head1);break;}case 7:{//打印用户信息print_user(head2);char name[MAX_BOOK1];printf("请输入要查找的用户名称:");scanf_s("%s", name, MAX_BOOK1);find_user(head2, name);break;}case 8:{//打印图书库存print_book(head3);break;}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}free_borrow(head1);free_book(head);
}//登录操作
bool user_log(UserLog *head)
{bool find_flag = false;//printf("%s %ld\n", name, password);char str1[] = { "admin" };char name[MAX_BOOK1] = { 0 };char password[20] = {0};printf("请输入用户名:");scanf_s("%s", name, MAX_BOOK1);printf("请输入密码:");scanf_s(" %s", password,20);if (strcmp(password, "888888") == 0 && strcmp(name, str1) == 0){find_flag = true;fun1();admin_log();}else{UserLog* p = head->next;while (p != NULL){if (strcmp(p->st.name, name) == 0 && strcmp(p->st.password, password) == 0){find_flag = true;fun2();student_log(p->st.name);}p = p->next;}}if(find_flag == false){printf("用户名及密码错误!!!请重新输入\n");}return true;}//用户登录
void student_log(char stuname[MAX_BOOK1])
{//图书借阅表BorrowList* head1 = init_borrow();file_readstuook(head1);//图书信息表BookList* head = init_book();file_readbook(head); //原始数据链表//fun2();//登录信息表UserLog* head2 = init_user();file_readuser(head2);BookList* head3 = init_book(); //图书库存链表file_readbook1(head3);while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:printf("退出用户登录\n");fun();return;case 1:{find_borrow(head1,stuname);//借阅图书unsigned int ID = 0;char name[MAX_BOOK1];//print_borrow(head1);printf("请依次输入图书ID,图书名称:");scanf_s("%d", &ID);scanf_s("%s", name, MAX_BOOK1);tail_borrow1(head1, head3,stuname,ID,name); //插入到个人显示find_borrow(head1, stuname);file_savestubook(head1); //借阅信息file_savebook1(head3); //图书库存信息printf("图书库存:\n");print_book(head);break;}case 2:{//归还图书//该用户的借阅信息find_borrow(head1, stuname);unsigned int ID = 0;char stuname[MAX_BOOK1];char name[MAX_BOOK1];printf("请依次输入借阅人,图书ID,图书名称:");scanf_s("%s", stuname, MAX_BOOK1);scanf_s("%d", &ID);scanf_s("%s", name, MAX_BOOK1);del_borrow1(head1, head3, stuname, ID, name);find_borrow(head1, stuname);file_savestubook(head1); //写入文件file_savebook1(head3); //图书库存信息printf("图书库存:\n");print_book(head3); //打印图书库存 还一本书就加1break;}case 3:{//读者查看图书库存print_book(head);break;}case 4:{//修改个人信息rework_user(head2, stuname);file_saveuser(head2);break;}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}free_borrow(head1);free_book(head);free_user(head2);}int main()
{//--------------图书管理系统----------------fun();UserLog* head = init_user();/*tail_user(head, "张三", "1", 123);tail_user(head, "郭胜雨", "11", 111);tail_user(head, "李四", "12", 222);tail_user(head, "王五", "13", 333);file_saveuser(head);*/file_readuser(head);//print_user(head);if (head == NULL) return 0;while (1){int n = 0;printf("select>");scanf_s("%d", &n);switch (n){case 0:printf("退出程序\n");return 0;case 1:{user_log(head); //登录账号break;}case 2:{ register_user(head); //注册用户file_saveuser(head);break;}default:printf("您输入的数据无效,请重新输入!!!\n");break;}}free_user(head);
}

相关文章:

基于C语言实现的图书管理系统

使用Visual Studio 2022编译工具进行编写代码的。 项目源码直接奉上: book1.h头文件: #ifndef __BOOK1_H //预处理用于条件编译 避免头文件反复包含 #define __BOOK1_H#include<stdio.h> #include <string.h> #include<stdlib.h> #include<stdbool.h&g…...

删除 需要来自XXXX的权限才能对此文件夹进行更改 文件的解决办法

如果你也是&#xff1a; 如果你也有类似上面的问题&#xff0c;这篇文章算是你看对了&#xff0c;哦哟&#xff01; 我的牙齿现在是怨灵的牙齿&#xff0c;可以啃下一头牛。 翻遍千山万水&#xff0c;咱们也是终于取到真经了家人们。 首先下一个everything好吗 甩一个官网链…...

ARM base instruction -- ccmp (immediate)

Conditional Compare (immediate) sets the value of the condition flags to the result of the comparison of a register value and an immediate value if the condition is TRUE, and an immediate value otherwise. 此指令一般出现在 cmp 指令之后&#xff0c;表示双重比…...

高德 阿里231滑块 分析

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 有相关问题请第一时间头像私信联系我删…...

Unity 的 WebGL 构建中资源图片访问方式

在 Unity 的 WebGL 构建中&#xff0c;资源图片是可以打包在 工程内部 使用的&#xff0c;前提是这些资源被正确地包含在构建中&#xff0c;并且能够通过合适的方式加载和访问。不同于传统的本地文件访问&#xff0c;WebGL 需要通过 Asset Bundles、Addressables 或 Resources …...

WinForms 中使用 MVVM 模式构建应用:实现登录页面、页面导航及 SQLite 数据库连接完整框架搭建过程

前言 在传统的 WinForms 应用程序开发中&#xff0c;很多开发者使用事件驱动的设计模式&#xff0c;直接将业务逻辑编写在界面代码中。然而&#xff0c;随着应用程序的复杂性增加&#xff0c;单一的界面文件变得臃肿&#xff0c;难以测试和维护。借鉴 WPF 中 MVVM&#xff08;…...

Chrome调试工具(查看CSS属性)

来说说这个Chrome调试工具吧&#xff0c;梦回gdb&#xff0c;但是它没有gdb难 打开浏览器 有两种方式可以直接打开Chrome调试工具 直接按F12 鼠标右键页面 --- 检查元素 什么mc玩家是鸣潮 标签页含义 &#x1f912; elements查看标签结构&#xff08;展示html文件&#…...

MQTT从入门到精通之MQTT入门

MQTT入门 1 MQTT概述 1.1 MQTT简介 MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;由IBM于1999年开发的一种基于**"发布订阅模式"的轻量级的消息传输协议**&#xff01; 发布订阅模式是一种传统的客户端-服务器架构的替代方案&#xff0c;因为…...

Hadoop生态系统主要包括哪些组件以及它们的作用

Hadoop生态系统是一个开源的大数据处理框架&#xff0c;它主要由一系列组件构成&#xff0c;每个组件都承担着不同的功能和作用。以下是Hadoop生态系统的主要组件及其作用的详细解释&#xff1a; HDFS&#xff08;Hadoop Distributed File System&#xff09; 作用&#xff1a…...

OpenResty 1.27.1.1 已经正式发布

OpenResty 1.27.1.1 已经正式发布&#xff0c;这是一个基于 NGINX 和 LuaJIT 的 web 平台。以下是关于此次发布的一些重点信息和更新内容&#xff1a; 下载与安装 你可以在此处下载最新版本的 OpenResty。提供了便携式源代码分发、Win32/Win64 二进制分发以及为 Ubuntu、Debi…...

定高虚拟列表:让大数据渲染变得轻松

定高虚拟列表 基本认识 在数据如潮水般涌来的今天&#xff0c;如何高效地展示和管理这些数据成为了开发者们面临的一大挑战&#xff0c;传统的列表渲染方式在处理大量数据时&#xff0c;往往会导致页面卡顿、滚动不流畅等问题&#xff0c;严重影响用户体验&#xff08;在页面…...

python request与grequests该如何选择

requests & grequests requests 和 grequests 是Python中用于发送HTTP请求的不同库。requests 是一个同步、阻塞式库&#xff0c;而 grequests 是基于 requests 封装的异步非阻塞库&#xff0c;它利用了 gevent 库提供的协程机制&#xff0c;能够并发发送多个请求。 选择…...

Unity3D UI 拖拽

Unity3D 实现 UI 元素拖拽功能。 UI 拖拽 通常画布上的 UI 元素都是固定位置的&#xff0c;我们可以通过实现拖拽接口&#xff0c;让 UI 元素可以被拖拽到其他位置。 拖拽接口 创建一个脚本 UIDrag.cs&#xff0c;在默认继承的 MonoBehaviour 后面&#xff0c;再继承三个接…...

介绍一下memcpy(c基础)

memcpy函数void *memcpy(void *dest, const void *src, size_t n); dest&#xff1a;指向目标内存区域的指针&#xff0c;即复制的目的地。src&#xff1a;指向源内存区域的指针&#xff0c;即要被复制的内容的来源。n&#xff1a;要复制的字节数 主要功能是将src所指向的内存…...

【网络面试篇】HTTP(2)(笔记)——http、https、http1.1、http2.0

目录 一、相关面试题 1. HTTP 与 HTTPS 有哪些区别&#xff1f; 2. HTTPS 的工作原理&#xff1f;&#xff08;https 是怎么建立连接的&#xff09; &#xff08;1&#xff09;ClientHello &#xff08;2&#xff09;SeverHello &#xff08;3&#xff09;客户端回应 &a…...

python-23-一篇文章帮你理解Python推导式

python-23-一篇文章帮你理解Python推导式 一.简介 在 Python 中&#xff0c;推导式&#xff08;Comprehensions&#xff09;是一个简洁的语法&#xff0c;用于通过某种可迭代对象快速生成新的对象&#xff08;如列表、字典、集合等&#xff01;来开始我们今天的日拱一卒&…...

WPF中如何简单的使用CommunityToolkit.Mvvm创建一个项目并进行 增删改查

目录 开始前准备的数据库dbblog如下&#xff1a; 第一步&#xff1a;创建项目后下载四个NuGet程序包 第二步&#xff1a;删除原本的MainWindow.XAML文件 并创建如下的目录结构 然后在View文件夹下面创建Login.XAML和Main.XAML 并且在App.XAML中将启动项改为Login.X…...

CesiumJS 案例 P15:检测标记、鼠标点击移动标记、鼠标拖动标记

CesiumJS CesiumJS API&#xff1a;https://cesium.com/learn/cesiumjs/ref-doc/index.html CesiumJS 是一个开源的 JavaScript 库&#xff0c;它用于在网页中创建和控制 3D 地球仪&#xff08;地图&#xff09; 一、检测标记 <!DOCTYPE html> <html lang"en&…...

Webserver(4.9)本地套接字的通信

目录 本地套接字 本地套接字 TCP\UDP实现不同主机、网络通信 本地套接字实现本地的进程间的通信&#xff0c;类似的&#xff0c;一般采用TCP的通信流程 生成套接字文件 #include<arpa/inet.h> #include<stdio.h> #include<stdlib.h> #include<unistd.h&…...

[IAA系列] Image Aesthetic Assessment

Preface 本文旨在记录个人结合AI工具对IAA这个领域的一些了解&#xff0c;主要是通过论文阅读的方式加深对领域的了解。有什么问题&#xff0c;欢迎在评论区提出并讨论。 什么是IAA Image Aesthetic Assessment&#xff08;图像美学评估&#xff09;是一种评估图像在视觉上的…...

基于springboot的高校科研管理系统(源码+调试+LW)

项目描述 临近学期结束&#xff0c;还是毕业设计&#xff0c;你还在做java程序网络编程&#xff0c;期末作业&#xff0c;老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据你想解决的问题&#xff0c;今天给…...

Flutter环境配置

配置环境变量 PUB_HOSTED_URLhttps://pub.flutter-io.cn FLUTTER_STORAGE_BASE_URLhttps://storage.flutter-io.cn 这个命令是用来配置 Flutter 的镜像源地址&#xff0c;主要是为了解决在中国大陆地区访问 Flutter 官方资源较慢的问题 具体的操作做如下: 右键点击"此…...

Rip动态路由及Rip动态路由优化

动态路由Rip Tip&#xff1a;Rip动态路由实现多个路由间不同网段通信。 本次实验目的&#xff0c;通过给ar1,ar2,ar3配置rip动态路由&#xff0c;实现pc1 ping通 pc2。 AR1配置如下&#xff1a; <Huawei>sy Enter system view, return user view with CtrlZ. [Huawei]…...

双路快速排序和三路排序算法

双路快速排序 一、概念及其介绍 双路快速排序算法是随机化快速排序的改进版本&#xff0c;partition 过程使用两个索引值&#xff08;i、j&#xff09;用来遍历数组&#xff0c;将 <v 的元素放在索引i所指向位置的左边&#xff0c;而将 >v 的元素放在索引j所指向位置的…...

SQL server增删改查语句和实例

在 SQL Server 中&#xff0c;增删改查操作分别对应 INSERT、DELETE、UPDATE 和 SELECT 语句。以下是具体介绍及实例&#xff1a; 一、插入数据&#xff08;INSERT&#xff09; 语法&#xff1a; INSERT INTO table_name (column1, column2, column3,...) VALUES (value1, val…...

强化学习_06_pytorch-PPO2实践(ALE/Breakout-v5)

一、环境适当调整 数据收集&#xff1a;RecordEpisodeStatistics进行起始跳过n帧&#xff1a;baseSkipFrame一条生命结束记录为done:EpisodicLifeEnv得分处理成0或1:ClipRewardEnv叠帧: FrameStack 图像环境的基本操作&#xff0c;方便CNN捕捉智能体的行动 向量空间reset处理修…...

《JVM第8课》垃圾回收算法

文章目录 1.标记算法1.1 引用计数法1.2 可达性分析法 2.回收算法2.1 标记-清除算法&#xff08;Mark-Sweep&#xff09;2.2 复制算法&#xff08;Coping&#xff09;2.3 标记-整理算法&#xff08;Mark-Compact&#xff09; 3.三种垃圾回收算法的对比 为什么要进行垃圾回收&…...

SpringBoot整合Freemarker(二)

if分支 语法&#xff1a; <#if condition>... <#elseif condition2>... <#elseif condition3>... <#else>... </#if> 例子&#xff1a; <#if x 1>x is 1 </#if> --------------------------------- <#if x 1>x is 1 <…...

element plus el-form自定义验证输入框为纯数字函数

element plus 的el-form 使用自定义验证器&#xff0c;验证纯数字&#xff0c;禁止输入小数、中文、字母、特殊符号。input的maxlength为最大输入多少位长度 效果图 <el-form ref"dataFormRef" :model"dataForm" :rules"dataRules" label-w…...

Android笔记(三十一):Deeplink失效问题

背景 通过deeplink启动应用之后&#xff0c;没关闭应用的情况下&#xff0c;再次使用deeplink会失效的问题&#xff0c;是系统bug导致的。此bug仅在某些设备&#xff08;Nexus 5X&#xff09;上重现&#xff0c;launchMode并且仅当应用程序最初通过深层链接启动并再次通过深层…...