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

C++核心编程——基于多态的企业职工系统

本专栏记录C++学习过程包括C++基础以及数据结构和算法,其中第一部分计划时间一个月,主要跟着黑马视频教程,学习路线如下,不定时更新,欢迎关注
当前章节处于:
---------第1阶段-C++基础入门
---------第2阶段实战-通讯录管理系统,
---------第3阶段-C++核心编程,
=====>第4阶段实战-基于多态的企业职工系统
---------第5阶段-C++提高编程
---------第6阶段实战-基于STL泛化编程的演讲比赛
---------第7阶段-C++实战项目机房预约管理系统

文章目录

  • 一、 项目介绍
  • 二、需求分析
  • 三、代码实现
    • 3.1 抽象类
    • 3.2 结构体
    • 3.3 显示菜单
    • 3.4 添加管理系统到文件
    • 3.5 添加员工信息
    • 3.6 显示系统
    • 3.7 删除员工信息
    • 3.8 修改员工信息
    • 3.9 查找员工信息
    • 3.10 按编号排序
    • 3.11 清空管理系统
    • 3.12 main主函数
  • 四、完整代码
  • 五、测试案例

一、 项目介绍

职工管理系统可以用来管理工资内所有员工的信息,要求利用C++来实现一个基于多态的职工管理系统。
公司中职工分为三类:普通职工、经理和老板,显示信息时需要显示职工编号、职工姓名、职工岗位以及职责。

  • 普通员工职责:完成经理交给的任务
  • 经理职责:完成老板交给的任务,并下发任务给员工
  • 老板职责:管理公司所有事务

管理系统中需要实现的功能如下:

  1. 退出管理系统
  2. 增加职工信息:实现批量添加职工功能,将信息录入到文件中,职工信息为:职工编号、姓名、部门编号
  3. 显示职工信息:显示公司内部所有职工的信息
  4. 删除离职员工:按照编号删除指定的职工
  5. 修改职工信息:按照编号修改职工个人信息
  6. 查找职工信息:按照职工的编号或者职工的姓名进行查找相关的人员信息
  7. 按照编号排序:按照职工编号,进行排序,排序规则由用户指定
  8. 清空所有文档:清空文件中记录的所有职工信息(清除前需要再次确认,防止误删)

二、需求分析

整个管理系统可以看成一个类数组,类数组中需要定义一个员工数,方便后面进行逻辑上的清空。首先需要抽象一个职工类作为父类,然后普通员工,经理和老板继承员工类作为子类,父类中需要定义职工编号,职工姓名,职工岗位三个属性。退出管理系统,说明整个是在一个while循环里面,批量增加员工信息说明是在for循环里面,实例化对象添加到类数组里面,为保证职工编号唯一需要添加判断。并且需要将信息录入文件中,则需要涉及到文件流的操作,因为后续会反复更新文件,所以需要将文件更新封装成函数。显示员工信息时,遍历类数组,并且需要判断类成员的部门编号,打印对应职责。删除、修改和查找大同小异,遍历找到之后再做下一个操作,值得注意的是,删除需要将员工数-1。这四个操作在开始前都需要判断一下员工数,如果等于0的话说明管理系统为空,给出提示并返回。按照编号排序,无非升序和降序,这里给一个变量让用户选择即可,使用冒泡排序对实例化对象中的序号进行排序。清空文档将类数组中员工数置零即可,做逻辑上的清空。为保证友好的交互,还应设计一个选择菜单,在循环中反复调用。

三、代码实现

3.1 抽象类

// 职工类
class Staff {
public:int numcard;  // 职工编号string name;  // 职工姓名string department; // 职工部门string work; // 职责
};
// 员工类
class Employee:public Staff {
};
// 经理类
class Manager :public Staff {
};
// 老板类boss
class Boss :public Staff {
};

3.2 结构体

// 管理系统结构体
struct Managersystem {Staff system[MaxNum];int peoplenum;
};

3.3 显示菜单

// 显示菜单
void showMenu() {cout << "-----欢迎来到职工管理系统----" << endl;cout << "     1.增加职工信息" << endl;cout << "     2.删除职工信息" << endl;cout << "     3.修改职工信息" << endl;cout << "     4.查找职工信息" << endl;cout << "     5.显示职工信息" << endl;cout << "     6.按照编号排序" << endl;cout << "     7.清空管理系统" << endl;cout << "     8.退出管理系统" << endl;
}

3.4 添加管理系统到文件

// 添加管理系统到文件
bool systemToFile(Managersystem& ms) {// 管理系统到文件fstream ofs;ofs.open("System.txt", ios::out);  // 如果不存在会先创建,先删除再创建for (int i = 0; i < ms.peoplenum; i++) {ofs << ms.system[i].numcard<<"    " << ms.system[i].name << "    " << ms.system[i].department << endl;}ofs.close();return true;
}

3.5 添加员工信息

// 添加员工信息
bool addStaff(Managersystem &ms) {// 达到最大值if (ms.peoplenum == MaxNum) {cout << "已达到系统所容纳最大人数,添加失败!" << endl;return false; // 退出}// 批量添加int allnum;cout << "请输入你要添加的人数:";cin >> allnum;bool foundDuplicate = false; // 标记int count = 0; // 统计人数for (int n = 0; n < allnum; n++) {int dp; // 部门string name; // 姓名int num; // 职工编号cout << "选择职位:" << endl;cout << "1.员工" << endl;cout << "2.经理" << endl;cout << "3.老板" << endl;cin >> dp;cout << "请输入职工编号:";cin >> num;// 保证编号的唯一性for (int i = 0; i < ms.peoplenum; i++) {if (num == ms.system[i].numcard) {cout << "该职员编号已存在!" << endl;foundDuplicate = true;break;}}if (foundDuplicate) {foundDuplicate = false; // 重置标记continue; // 跳过当前外部循环,继续执行下一次外部循环}cout << "请输入姓名:" ;cin >> name;if (dp == 1) {Employee ep;ep.name = name;ep.numcard = num;ep.department = "员工";ep.work = "完成经理交给的任务";ms.system[ms.peoplenum] = ep;}else if (dp == 2) {Manager mg;mg.name = name;mg.numcard = num;mg.department = "经理";mg.work = "完成老板交给的任务,并下发任务给员工";ms.system[ms.peoplenum] = mg;}else {Boss bs;bs.name = name;bs.numcard = num;bs.department = "老板";bs.work = "管理公司所有事务";ms.system[ms.peoplenum] = bs;}count++;ms.peoplenum++;}cout << "一共添加了" << count << "人!" << endl;return true;
}

3.6 显示系统

// 显示系统
void showSystem(const Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return;}for (int i = 0; i < ms.peoplenum; i++) {cout << "员工编号:" << ms.system[i].numcard<<"  部门:" << ms.system[i].department <<"   姓名:"<< ms.system[i].name  <<"   \t职责:"<< ms.system[i].work << endl;}
}

3.7 删除员工信息

// 删除职工信息
bool deleteStaff(Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return false;}int numcard;cout << "请输入你要删除的职工编号:";cin >> numcard;for (int i = 0; i < ms.peoplenum; i++) {if (ms.system[i].numcard == numcard) {if (ms.peoplenum == 1) {cout << "走这" << endl;ms.peoplenum = 0; // 系统里面就一个人,直接做逻辑删除}else {// 比如i=1,一共有4个,j需要从1开始到3for (int j = i; j < ms.peoplenum; j++) {ms.system[j] = ms.system[j + 1];  // 后面的移到前面}ms.peoplenum--;}return true;}}cout << "没有你要删除的编号!" << endl;return false;
}

3.8 修改员工信息

// 修改职工信息
bool changeStaff(Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return false;}int numcard;cout << "请输入你要修改的职工编号:";cin >> numcard;string target;for (int i = 0; i < ms.peoplenum; i++) {if (ms.system[i].numcard == numcard) {cout << "请输入你要修改的信息:";cin >> target;if (target.compare("编号") == 0) {int targetnum;cout << "请输入修改之后的编号:";cin >> targetnum;ms.system[i].numcard = targetnum;return true;}else if (target.compare("姓名") == 0) {string targetname;cout << "请输入修改之后的姓名:";cin >> targetname;ms.system[i].name = targetname;return true;}else if (target.compare("部门") == 0) {string targetdp;cout << "请输入修改之后的部门:";cin >> targetdp;ms.system[i].department = targetdp;return true;}else {cout << "没有这个选项!" << endl;return false;}}}
}

3.9 查找员工信息

// 查找职员信息
bool findStaff(Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return false;}int numcard;cout << "请输入你要查找的职工编号:";cin >> numcard;string target;for (int i = 0; i < ms.peoplenum; i++) {if (ms.system[i].numcard == numcard) {cout << "员工编号:" << ms.system[i].numcard << "  部门:" << ms.system[i].department << "   姓名:" << ms.system[i].name << "   职责:" << ms.system[i].work << endl;return true;}}cout << "查无此人!" << endl;return false;
}

3.10 按编号排序

// 按照编号排序
void popStaff(Managersystem& ms) {int choice;cout << "请输入排序方式:" << endl;cout << "1.顺序" << endl;cout << "2.逆序" << endl;cin >> choice;if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return;}if (choice == 1) {for (int i = 0; i < ms.peoplenum - 1; i++) {for (int j = 0; j < ms.peoplenum - i - 1; j++) {// 冒泡排序if (ms.system[j].numcard > ms.system[j + 1].numcard) {// 交换Staff temp = ms.system[j];ms.system[j] = ms.system[j + 1];ms.system[j + 1] = temp;}}}}else {for (int i = 0; i < ms.peoplenum - 1; i++) {for (int j = 0; j < ms.peoplenum - i - 1; j++) {// 冒泡排序if (ms.system[j].numcard < ms.system[j + 1].numcard) {// 交换Staff temp = ms.system[j];ms.system[j] = ms.system[j + 1];ms.system[j + 1] = temp;}}}}showSystem(ms);
}

3.11 清空管理系统

// 清空管理系统
bool deleteSystem(Managersystem& ms) {// 做逻辑情况int choice;cout << "是否清空管理系统:" << endl;cout << "1.Yes" << endl;cout << "2.No" << endl;cin >> choice;if (choice == 1) {ms.peoplenum = 0; // 逻辑清空return true;}return false;
}

3.12 main主函数

int main() {// 创建一个管理系统结构体Managersystem mainsystem;mainsystem.peoplenum = 0; // 开始时置零while (1) {showMenu();int choice;cout << "请输入你的选项:";cin >> choice;switch (choice){case 1:addStaff(mainsystem);systemToFile(mainsystem);break;case 2:deleteStaff(mainsystem);systemToFile(mainsystem);break;case 3:changeStaff(mainsystem);systemToFile(mainsystem);break;case 4:findStaff(mainsystem);break;case 5:showSystem(mainsystem);break;case 6:popStaff(mainsystem);systemToFile(mainsystem);break;case 7:deleteSystem(mainsystem);systemToFile(mainsystem);break;case 8:return 0;default:cout << "没有这个选项!" << endl;break;}}system("pause");return 0;
}

四、完整代码

#include <iostream>
using namespace std;
#include <fstream>
// 定义员工系统最大容纳人数
#define MaxNum 100
// 职工类
class Staff {
public:int numcard;  // 职工编号string name;  // 职工姓名string department; // 职工部门string work; // 职责
};
// 员工类
class Employee:public Staff {
};
// 经理类
class Manager :public Staff {
};
// 老板类boss
class Boss :public Staff {
};
// 管理系统结构体
struct Managersystem {Staff system[MaxNum];int peoplenum;
};
// 显示菜单
void showMenu() {cout << "-----欢迎来到职工管理系统----" << endl;cout << "     1.增加职工信息" << endl;cout << "     2.删除职工信息" << endl;cout << "     3.修改职工信息" << endl;cout << "     4.查找职工信息" << endl;cout << "     5.显示职工信息" << endl;cout << "     6.按照编号排序" << endl;cout << "     7.清空管理系统" << endl;cout << "     8.退出管理系统" << endl;
}
// 添加管理系统到文件
bool systemToFile(Managersystem& ms) {// 管理系统到文件fstream ofs;ofs.open("System.txt", ios::out);  // 如果不存在会先创建,先删除再创建for (int i = 0; i < ms.peoplenum; i++) {ofs << ms.system[i].numcard<<"    " << ms.system[i].name << "    " << ms.system[i].department << endl;}ofs.close();return true;
}
// 添加员工信息
bool addStaff(Managersystem &ms) {// 达到最大值if (ms.peoplenum == MaxNum) {cout << "已达到系统所容纳最大人数,添加失败!" << endl;return false; // 退出}// 批量添加int allnum;cout << "请输入你要添加的人数:";cin >> allnum;bool foundDuplicate = false; // 标记int count = 0; // 统计人数for (int n = 0; n < allnum; n++) {int dp; // 部门string name; // 姓名int num; // 职工编号cout << "选择职位:" << endl;cout << "1.员工" << endl;cout << "2.经理" << endl;cout << "3.老板" << endl;cin >> dp;cout << "请输入职工编号:";cin >> num;// 保证编号的唯一性for (int i = 0; i < ms.peoplenum; i++) {if (num == ms.system[i].numcard) {cout << "该职员编号已存在!" << endl;foundDuplicate = true;break;}}if (foundDuplicate) {foundDuplicate = false; // 重置标记continue; // 跳过当前外部循环,继续执行下一次外部循环}cout << "请输入姓名:" ;cin >> name;if (dp == 1) {Employee ep;ep.name = name;ep.numcard = num;ep.department = "员工";ep.work = "完成经理交给的任务";ms.system[ms.peoplenum] = ep;}else if (dp == 2) {Manager mg;mg.name = name;mg.numcard = num;mg.department = "经理";mg.work = "完成老板交给的任务,并下发任务给员工";ms.system[ms.peoplenum] = mg;}else {Boss bs;bs.name = name;bs.numcard = num;bs.department = "老板";bs.work = "管理公司所有事务";ms.system[ms.peoplenum] = bs;}count++;ms.peoplenum++;}cout << "一共添加了" << count << "人!" << endl;return true;
}
// 显示系统
void showSystem(const Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return;}for (int i = 0; i < ms.peoplenum; i++) {cout << "员工编号:" << ms.system[i].numcard<<"  部门:" << ms.system[i].department <<"   姓名:"<< ms.system[i].name  <<"   \t职责:"<< ms.system[i].work << endl;}
}
// 删除职工信息
bool deleteStaff(Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return false;}int numcard;cout << "请输入你要删除的职工编号:";cin >> numcard;for (int i = 0; i < ms.peoplenum; i++) {if (ms.system[i].numcard == numcard) {if (ms.peoplenum == 1) {cout << "走这" << endl;ms.peoplenum = 0; // 系统里面就一个人,直接做逻辑删除}else {// 比如i=1,一共有4个,j需要从1开始到3for (int j = i; j < ms.peoplenum; j++) {ms.system[j] = ms.system[j + 1];  // 后面的移到前面}ms.peoplenum--;}return true;}}cout << "没有你要删除的编号!" << endl;return false;
}
// 修改职工信息
bool changeStaff(Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return false;}int numcard;cout << "请输入你要修改的职工编号:";cin >> numcard;string target;for (int i = 0; i < ms.peoplenum; i++) {if (ms.system[i].numcard == numcard) {cout << "请输入你要修改的信息:";cin >> target;if (target.compare("编号") == 0) {int targetnum;cout << "请输入修改之后的编号:";cin >> targetnum;ms.system[i].numcard = targetnum;return true;}else if (target.compare("姓名") == 0) {string targetname;cout << "请输入修改之后的姓名:";cin >> targetname;ms.system[i].name = targetname;return true;}else if (target.compare("部门") == 0) {string targetdp;cout << "请输入修改之后的部门:";cin >> targetdp;ms.system[i].department = targetdp;return true;}else {cout << "没有这个选项!" << endl;return false;}}}
}
// 查找职员信息
bool findStaff(Managersystem& ms) {if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return false;}int numcard;cout << "请输入你要查找的职工编号:";cin >> numcard;string target;for (int i = 0; i < ms.peoplenum; i++) {if (ms.system[i].numcard == numcard) {cout << "员工编号:" << ms.system[i].numcard << "  部门:" << ms.system[i].department << "   姓名:" << ms.system[i].name << "   职责:" << ms.system[i].work << endl;return true;}}cout << "查无此人!" << endl;return false;
}
// 按照编号排序
void popStaff(Managersystem& ms) {int choice;cout << "请输入排序方式:" << endl;cout << "1.顺序" << endl;cout << "2.逆序" << endl;cin >> choice;if (ms.peoplenum == 0) {cout << "系统为空!" << endl;return;}if (choice == 1) {for (int i = 0; i < ms.peoplenum - 1; i++) {for (int j = 0; j < ms.peoplenum - i - 1; j++) {// 冒泡排序if (ms.system[j].numcard > ms.system[j + 1].numcard) {// 交换Staff temp = ms.system[j];ms.system[j] = ms.system[j + 1];ms.system[j + 1] = temp;}}}}else {for (int i = 0; i < ms.peoplenum - 1; i++) {for (int j = 0; j < ms.peoplenum - i - 1; j++) {// 冒泡排序if (ms.system[j].numcard < ms.system[j + 1].numcard) {// 交换Staff temp = ms.system[j];ms.system[j] = ms.system[j + 1];ms.system[j + 1] = temp;}}}}showSystem(ms);
}
// 清空管理系统
bool deleteSystem(Managersystem& ms) {// 做逻辑情况int choice;cout << "是否清空管理系统:" << endl;cout << "1.Yes" << endl;cout << "2.No" << endl;cin >> choice;if (choice == 1) {ms.peoplenum = 0; // 逻辑清空return true;}return false;
}
int main() {// 创建一个管理系统结构体Managersystem mainsystem;mainsystem.peoplenum = 0; // 开始时置零while (1) {showMenu();int choice;cout << "请输入你的选项:";cin >> choice;switch (choice){case 1:addStaff(mainsystem);systemToFile(mainsystem);break;case 2:deleteStaff(mainsystem);systemToFile(mainsystem);break;case 3:changeStaff(mainsystem);systemToFile(mainsystem);break;case 4:findStaff(mainsystem);break;case 5:showSystem(mainsystem);break;case 6:popStaff(mainsystem);systemToFile(mainsystem);break;case 7:deleteSystem(mainsystem);systemToFile(mainsystem);break;case 8:return 0;default:cout << "没有这个选项!" << endl;break;}}system("pause");return 0;
}

五、测试案例

-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:1
请输入你要添加的人数:3
选择职位:
1.员工
2.经理
3.老板
1
请输入职工编号:1
请输入姓名:张三
选择职位:
1.员工
2.经理
3.老板
2
请输入职工编号:2
请输入姓名:李四
选择职位:
1.员工
2.经理
3.老板
3
请输入职工编号:3
请输入姓名:王五
一共添加了3人!
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:5
员工编号:1  部门:员工   姓名:张三    职责:完成经理交给的任务
员工编号:2  部门:经理   姓名:李四    职责:完成老板交给的任务,并下发任务给员工
员工编号:3  部门:老板   姓名:王五    职责:管理公司所有事务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:2
请输入你要删除的职工编号:2
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:5
员工编号:1  部门:员工   姓名:张三    职责:完成经理交给的任务
员工编号:3  部门:老板   姓名:王五    职责:管理公司所有事务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:3
请输入你要修改的职工编号:1
请输入你要修改的信息:部门
请输入修改之后的部门:经理
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:5
员工编号:1  部门:经理   姓名:张三    职责:完成经理交给的任务
员工编号:3  部门:老板   姓名:王五    职责:管理公司所有事务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:4
请输入你要查找的职工编号:1
员工编号:1  部门:经理   姓名:张三   职责:完成经理交给的任务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:4
请输入你要查找的职工编号:2
查无此人!
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:1
请输入你要添加的人数:1
选择职位:
1.员工
2.经理
3.老板
1
请输入职工编号:2
请输入姓名:赵六
一共添加了1人!
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:1
请输入你要添加的人数:1
选择职位:
1.员工
2.经理
3.老板
1
请输入职工编号:1
该职员编号已存在!
一共添加了0人!
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:5
员工编号:1  部门:经理   姓名:张三    职责:完成经理交给的任务
员工编号:3  部门:老板   姓名:王五    职责:管理公司所有事务
员工编号:2  部门:员工   姓名:赵六    职责:完成经理交给的任务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:6
请输入排序方式:
1.顺序
2.逆序
1
员工编号:1  部门:经理   姓名:张三    职责:完成经理交给的任务
员工编号:2  部门:员工   姓名:赵六    职责:完成经理交给的任务
员工编号:3  部门:老板   姓名:王五    职责:管理公司所有事务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:6
请输入排序方式:
1.顺序
2.逆序
2
员工编号:3  部门:老板   姓名:王五    职责:管理公司所有事务
员工编号:2  部门:员工   姓名:赵六    职责:完成经理交给的任务
员工编号:1  部门:经理   姓名:张三    职责:完成经理交给的任务
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:7
是否清空管理系统:
1.Yes
2.No
1
-----欢迎来到职工管理系统----1.增加职工信息2.删除职工信息3.修改职工信息4.查找职工信息5.显示职工信息6.按照编号排序7.清空管理系统8.退出管理系统
请输入你的选项:8D:\桌面\C++学习\1.14\x64\Debug\1.14.exe (进程 5464)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

相关文章:

C++核心编程——基于多态的企业职工系统

本专栏记录C学习过程包括C基础以及数据结构和算法&#xff0c;其中第一部分计划时间一个月&#xff0c;主要跟着黑马视频教程&#xff0c;学习路线如下&#xff0c;不定时更新&#xff0c;欢迎关注。 当前章节处于&#xff1a; ---------第1阶段-C基础入门 ---------第2阶段实战…...

Nginx服务安装

Nginx(发音为[engine x]&#xff09;专为性能优化而开发&#xff0c;其最知名的优点是它的稳定性和低系统资源消 耗&#xff0c;以及对HTTP并发连接的高处理能力&#xff08;单台物理服务器可支持30000~50000个并发请求&#xff09;。正因 为如此&#xff0c;大量提供社交网络、…...

微信小程序canvas画布实现矩形元素自由缩放、移动功能

一、获取画布信息并绘制背景 .whml <canvas class="canvas" type="2d" id="myCanvas" bindtouchstart="get_rect_touch_position" bindtouchmove="move_or_scale" bind:tap="finish_edit_check"/> 定义c…...

一文搞懂 Python 3 中的数据类型

介绍 在 Python 中&#xff0c;与所有编程语言一样&#xff0c;数据类型用于对一种特定类型的数据进行分类。这很重要&#xff0c;因为您使用的特定数据类型将决定您可以为其分配哪些值以及您可以对其执行哪些操作&#xff08;包括可以对其执行哪些操作&#xff09;。 1. 数字…...

学习笔记之——3D Gaussian Splatting源码解读

之前博客对3DGS进行了学习与调研 学习笔记之——3D Gaussian Splatting及其在SLAM与自动驾驶上的应用调研-CSDN博客文章浏览阅读450次。论文主页3D Gaussian Splatting是最近NeRF方面的突破性工作&#xff0c;它的特点在于重建质量高的情况下还能接入传统光栅化&#xff0c;优…...

Flink standalone集群部署配置

文章目录 简介软件依赖部署方案二、安装1.下载并解压2.ssh免密登录3.修改配置文件3.启动集群4.访问 Web UI 简介 Flink独立模式&#xff08;Standalone&#xff09;是部署 Flink 最基本也是最简单的方式&#xff1a;所需要的所有 Flink 组件&#xff0c; 都只是操作系统上运行…...

Python: + 运算符、append() 方法和 extend()方法的区别和用法

在Python中&#xff0c;有几种常见的方式可以向列表中添加元素&#xff0c;其中包括使用 运算符、append() 方法和 extend() 方法。 使用 运算符&#xff1a; 运算符用于合并两个列表。 通过创建一个新列表&#xff0c;包含两个被合并的列表的元素。不会修改原始列表&…...

【MySQL】mysql集群

文章目录 一、mysql日志错误日志查询日志二进制日志慢查询日志redo log和undo log 二、mysql集群主从复制原理介绍配置命令 读写分离原理介绍配置命令 三、mysql分库分表垂直拆分水平拆分 一、mysql日志 MySQL日志 是记录 MySQL 数据库系统运行过程中不同事件和操作的信息的文件…...

zabbix监控windows主机

下载安装zabbix agent安装包 Zabbix官网下载地址: https://www.zabbix.com/cn/download_agents?version5.0LTS&release5.0.40&osWindows&os_versionAny&hardwareamd64&encryptionOpenSSL&packagingMSI&show_legacy0 这里使用zabbix agent2 安装 …...

单例模式的八种写法、单例和并发的关系

文章目录 1.单例模式的作用2.单例模式的适用场景3.饿汉式静态常量&#xff08;可用&#xff09;静态代码块&#xff08;可用&#xff09; 4.懒汉式线程不安全&#xff08;不可用&#xff09;同步方法&#xff08;线程安全&#xff0c;但不推荐用&#xff09;同步代码块&#xf…...

基于实时Linux+FPGA实现NI CompactRIO系统详解

利用集成的软件工具链&#xff0c;结合信号调理I/O模块&#xff0c;轻松构建和部署实时应用程序。 什么是CompactRIO&#xff1f; CompactRIO系统提供了高处理性能、传感器专用I/O和紧密集成的软件工具&#xff0c;使其成为工业物联网、监测和控制应用的理想之选。实时处理器提…...

Webhook端口中的自定义签名身份认证

概述 如果需要通过 Webhook 端口从交易伙伴处接收数据&#xff0c;但该交易伙伴可能对于安全性有着较高的要求&#xff0c;而不仅仅是用于验证入站 Webhook 要求的基本身份验证用户名/密码&#xff0c;或者用户可能只想在入站 Webhook 消息上增加额外的安全层。 使用 Webhook…...

用Linux的视角来理解缓冲区概念

缓冲区的认识 缓冲区&#xff08;buffer&#xff09;是存储数据的临时存储区域。当我们用C语言向文件中写入数据时&#xff0c;数据并不会直接的写到文件中&#xff0c;中途还经过了缓冲区&#xff0c;而我们需要对缓冲区的数据进行刷新&#xff0c;那么数据才算写到文件当中。…...

C#中Enumerable.Range(Int32, Int32) 方法用于计算

目录 一、关于Enumerable.Range(Int32, Int32) 方法 1.定义 2.Enumerable.Range(&#xff09;用于数学计算的操作方法 3.实例1&#xff1a;显示整型数1~9的平方 4.实例2&#xff1a;显示整型数0~9 5.实例3&#xff1a;Enumerable.Range(&#xff09;vs for循环 &#x…...

Linux和windows进程同步与线程同步那些事儿(四):windows 下进程同步

Linux和windows进程同步与线程同步那些事儿&#xff08;一&#xff09; Linux和windows进程同步与线程同步那些事儿&#xff08;二&#xff09;&#xff1a; windows线程同步详解示例 Linux和windows进程同步与线程同步那些事儿&#xff08;三&#xff09;&#xff1a; Linux线…...

1. Logback介绍

Logback介绍 Logback旨在成为流行的log4j项目的继任者。它由Ceki Glc设计&#xff0c;他是log4j的创始人。它基于十年在设计工业级日志系统方 面的经验。结果产品&#xff0c;即logback&#xff0c;比所有现有的日志系统更快&#xff0c;具有更小的占用空间&#xff0c;有时差距…...

SqueezeNet:通过紧凑架构彻底改变深度学习

一、介绍 在深度学习领域&#xff0c;对效率和性能的追求往往会带来创新的架构。SqueezeNet 是神经网络设计的一项突破&#xff0c;体现了这种追求。本文深入研究了 SqueezeNet 的复杂性&#xff0c;探讨其独特的架构、设计背后的基本原理、应用及其对深度学习领域的影响。 在创…...

Python:正则表达式之re.group()用法

Python正则表达式之re.group()用法学习笔记 正则表达式是在处理字符串时非常有用的工具&#xff0c;而re.group()是在匹配到的文本中提取特定分组内容的方法之一。 1. re.group()的基本用法 在正则表达式中&#xff0c;通过圆括号可以创建一个或多个分组。re.group()用于获取…...

Shiro框架:Shiro登录认证流程源码解析

目录 1.用户登录认证流程 1.1 生成认证Token 1.2 用户登录认证 1.2.1 SecurityManager login流程解析 1.2.1.1 authenticate方法进行登录认证 1.2.1.1.1 单Realm认证 1.2.1.2 认证通过后创建登录用户对象 1.2.1.2.1 复制SubjectContext 1.2.1.2.2 对subjectContext设…...

WEB前端人机交互导论实验-实训2格式化文本、段落与列表

1.项目1 文本与段落标记的应用&#xff1a; A.题目要求: B.思路&#xff1a; &#xff08;1&#xff09;首先&#xff0c;HTML文档的基本结构是通过<html>...</html>标签包围的&#xff0c;包含了头部信息和页面主体内容。 &#xff08;2&#xff09;在头部信息…...

Python:list列表与tuple元组的区别

在Python中&#xff0c;List&#xff08;列表&#xff09; 和Tuple&#xff08;元组&#xff09; 都是用于存储一组有序元素的数据结构&#xff0c;但它们有一些关键的区别&#xff0c;包括可变性、性能、语法等方面。 1. List&#xff08;列表&#xff09; 用法&#xff1a;…...

如何基于 Gin 封装出属于自己 Web 框架?

思路 在基于 Gin 封装出属于自己的 Web 框架前&#xff0c;你需要先了解 Gin 的基本用法和设计理念。 然后&#xff0c;你可以通过以下步骤来封装自己的 Web 框架&#xff1a; 封装路由&#xff1a;Gin 的路由是通过 HTTP 方法和 URL 路径进行匹配的&#xff0c;你可以根据自己…...

VUE element-ui实现表格动态展示、动态删减列、动态排序、动态搜索条件配置、表单组件化。

1、实现效果 1.1、文件目录 1.2、说明 1、本组件支持列表的表头自定义配置&#xff0c;checkbox实现 2、本组件支持列表列排序&#xff0c;vuedraggable是拖拽插件&#xff0c;上图中字段管理里的拖拽效果 &#xff0c;需要的话请自行npm install 3、本组件支持查询条件动态…...

压测工具ab

Apache Benchmark(简称ab) 是Apache安装包中自带的压力测试工具 &#xff0c;简单易用, Apache的ab命令模拟多线程并发请求&#xff0c;测试服务器负载压力&#xff0c;也可以适用于其他服务&#xff1a;nginx、lighthttp、tomcat、IIS等其它Web服务器的压力 采用平台&#xf…...

P4学习(一) 环境搭建

系列文章目录 第一章 P4学习入门之虚拟机环境搭建 文章目录 系列文章目录前言一、P4是什么&#xff1f;二、搭建步骤1.下载虚拟机镜像2.虚拟机管理软件载入镜像2.1 找到你镜像的所在位置2.2 打开VMware Workstation2.3 载入镜像 3.检验环境是否配置成功 P4 的真机环境搭建 前言…...

openssl3.2 - 官方demo学习 - server-arg.c

文章目录 openssl3.2 - 官方demo学习 - server-arg.c概述笔记备注END openssl3.2 - 官方demo学习 - server-arg.c 概述 TLS服务器, 等客户端来连接; 如果客户端断开了, 通过释放bio来释放客户端socket, 然后继续通过bio读来aceept. 笔记 对于开源工程, 不可能有作者那么熟悉…...

Windows RPC运行时漏洞事后总结

2022年4月前后&#xff0c;Windows RPC运行时被曝出存在远程代码执行漏洞&#xff0c;当时曾引起很多人广泛关注。微软很快做出反应&#xff0c;发布补丁程序进行修补。这次事件中&#xff0c;Windows远程过程调用&#xff08;RPC&#xff09;运行时共出现三个关键漏洞&#xf…...

运算电路(1)——加法器

一、引言 微处理器是由一片或少数几片大规模集成电路组成的中央处理器。这些电路执行控制部件和算术逻辑部件的功能。微处理器能完成取指令、执行指令&#xff0c;以及与外界存储器和逻辑部件交换信息等操作&#xff0c;是微型计算机的运算控制部分。它可与存储器和外围电路芯片…...

ESP32-WIFI(Arduino)

ESP32-WIFI Wi-Fi是一种基于IEEE 802.11标准的无线局域网技术&#xff0c;是Wi-Fi联盟制造商的商标作为产品的品牌认证。它可以让电脑、手机、平板电脑等设备通过无线信号连接到互联网 。 在无线网络中&#xff0c;AP&#xff08;Access Point&#xff09;和 STA&#xff08;St…...

【网络虚拟化】网络设备常见冗余方式——堆叠、M-Lag、DRNI

网络设备常见冗余设计——堆叠、M-Lag、DRNI 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 网络设备常见冗余设计——堆叠、M-Lag、DRNI 网络设备常见冗余设计——堆叠、M-Lag、DRNI前言一、网络设备虚拟化二、堆叠技术1.技术原理2.…...