既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
void exitSystem();
// 记录职工人数
int workerNum;
// 职工的数组
Worker \*\* workerArray;
void addWorker();
// 保存文件,持久化
void save();
bool isFileEmpty;
// 统计人数
int getWorkerNum();
// 初始化员工
void initWorker();
// 删除职工
void delEmp();
// 判断职工是否存在
int isExist(int id);
// 修改员工
void updateEmp();
// 查找员工
void findEmp();
// 按照编号排序
void sortEmp();
// 清空文件
void cleanFile();
// 析构函数
~WorkerManager();
};
### cpp文件中具体实现
#include “workerManage.h”
WorkerManager::WorkerManager()
{
// 文件不存在
ifstream ifs;
ifs.open(FILENAME, ios::in); // 读取文件
if (!ifs.is_open())
{
cout << “文件不存” << endl;
this->workerNum = 0;
this->workerArray = NULL;
this->isFileEmpty = true; // 是否为空
ifs.close();
return;
}
// 文件存在,数据为空
char ch;
ifs >> ch;
if (ifs.eof()) // 代表文件为空
{
cout << “文件为空” << endl;
this->workerNum = 0;
this->workerArray = NULL;
this->isFileEmpty = true; // 是否为空
ifs.close();
return;
}
// 当文件存在,且记录有数据
int num = this->getWorkerNum();
cout << "职工人数为:" << num << endl;
this->workerNum = num;
this->workerArray = new Worker \* [this->workerNum];
// 将文件中数据存到数组中
this->initWorker();
}
void WorkerManager::ShowMenu()
{
cout << “=" << endl;
cout << “职工管理系统” << endl;
cout << “1、添加职工” << endl;
cout << “2、显示职工” << endl;
cout << “3、删除职工” << endl;
cout << “4、修改职工” << endl;
cout << “5、查找职工” << endl;
cout << “6、排序职工” << endl;
cout << “7、清空文件” << endl;
cout << “0、退出系统” << endl;
cout << "=” << endl;
}
void WorkerManager::ShowEmp()
{
// 判断文件是否为空
if (this->isFileEmpty)
{
cout << “文件不存在” << endl;
}
else
{
// 输出原有的员工
for (int i = 0; i < this->workerNum; i++)
{
workerArray[i]->showInfo(); // 利用多态调用程序接口
}
}
system(“pause”);
system(“cls”);
}
void WorkerManager::exitSystem()
{
cout << “欢迎下次使用” << endl;
system(“pause”);
exit(0); // 直接退出
}
void WorkerManager::addWorker()
{
cout << “输入添加的职工数量” << endl;
int addNum = 0;
cin >> addNum;
if (addNum>0)
{
// 计算添加的空间大小
int newSize = this->workerNum + addNum;
// 开辟新空间 写入newSpace时缓存区溢出
Worker \*\* newSpace = new Worker\* [newSize];
// 原来是不是空的
if (this->workerArray !=NULL)
{
for (int i = 0; i < this->workerNum; i++)
{
newSpace[i] = this->workerArray[i];
}
}
// 添加新的数据
for (int i = 0; i < addNum; i++)
{
int id; // 职工编号
string name; // 职工姓名
int dId; // 部分编码
cout << "输入第" << i+1 << " 个新职工的编号" << endl;
cin >> id;
cout << "输入第" << i + 1 << " 个新职工的姓名" << endl;
cin >> name;
cout << "选择第" << i + 1 << " 个新职工的岗位" << endl;
cout << "1普通,2经理,3老板" << endl;
cin >> dId;
Worker \* worker = NULL;
switch (dId)
{
case 1:
worker = new Emp(id, name, 1);
break;
case 2:
worker = new Manager(id, name, 2);
break;
case 3:
worker = new Boss(id, name, 3);
break;
default:
break;
}
// 将创建的职工指针保存到数组中
newSpace[this->workerNum + i] = worker;
}
// 释放原有空间
delete[] this->workerArray;
// 更改新空间的指向
this->workerArray = newSpace;
this->workerNum = newSize;
cout << "添加了" << addNum << " 个员工" << endl;
this->isFileEmpty = false; // 是否为空
// 保存数据到文件中
this->save();
}
else {
cout << "输入有误" << endl;
}
system("pause");
system("cls");
}
void WorkerManager::save()
{
ofstream ofs;
ofs.open(FILENAME, ios::out); // 用输出的方式打开文件
for (int i = 0; i < this->workerNum; i++)
{
ofs << this->workerArray[i]->id << " "
<< this->workerArray[i]->name << " "
<< this->workerArray[i]->dep << endl;
}
}
int WorkerManager::getWorkerNum()
{
ifstream ifs;
ifs.open(FILENAME, ios::in); // 读取文件
int id;
string name;
int dId;
int num = 0;
while (ifs >> id && ifs >> name && ifs >> dId)
{
num++;
}
return num;
}
void WorkerManager::initWorker()
{
ifstream ifs;
ifs.open(FILENAME, ios::in);
int id;
string name;
int dId;
int index = 0;
while (ifs >> id && ifs >> name && ifs >> dId) {
Worker\* worker = NULL;
if (dId == 1) // 普通员工
{
worker = new Emp(id, name, dId);
}
else if (dId == 2) // 经理
{
worker = new Manager(id, name, dId);
}
else
{
worker = new Boss(id, name, dId);
}
this->workerArray[index] = worker;
index++;
}
// 关闭文件
ifs.close();
}
void WorkerManager::delEmp()
{
if (this->isFileEmpty)
{
cout << “文件不存在或者为空” << endl;
}
else {
// 输入要删除的员工的id
cout << “输入要删除的员工的id” << endl;
int id = 0;
cin >> id;
if (this->isExist(id) != -1) // 存在
{
for (int i = id; i < this->workerNum -1; i++)
{
this->workerArray[i] = this->workerArray[i + 1];
}
this->workerNum–; // 更新人员数量
// 更新文件
this->save();
}
else {
cout << “未找到职工” << endl;
}
}
system(“pause”);
system(“cls”);
}
int WorkerManager::isExist(int id)
{
int index = -1;
for (int i = 0; i < this->workerNum; i++)
{
if (this->workerArray[i]->id == id )
{
index = i; // 找到了职工
break;
}
}
return index;
}
void WorkerManager::updateEmp()
{
if (this->isFileEmpty)
{
cout << “文件为空,或者不存在” << endl;
}
else
{
cout << “输入要修改的员工编号” << endl;
int id;
cin >> id;
int index = this->isExist(id);
if (index != -1)
{
delete this->workerArray[index];
int newId = 0;
string newName = “”;
int dId = 0;
cout << “输入第职工的新编号” << endl;
cin >> newId;
cout << “输入职工的新姓名” << endl;
cin >> newName;
cout << “选择职工的新岗位” << endl;
cout << “1普通,2经理,3老板” << endl;
cin >> dId;
Worker\* worker = NULL;
switch (dId)
{
case 1:
worker = new Emp(newId, newName, dId);
break;
case 2:
worker = new Manager(newId, newName, dId);
break;
case 3:
worker = new Boss(newId, newName, dId);
break;
default:
break;
}
// 更新到数组中
this->workerArray[index] = worker;
cout << "修改成功" << endl;
this->save();
}
else
{
cout << "修改失败,查无此人" << endl;
}
}
system("pause");
system("cls");
}
void WorkerManager::findEmp()
{
if (this->isFileEmpty)
{
cout << “文件为空,或者不存在” << endl;
}
else {
cout << “输入查找方式,1.按照编号,2.按照姓名” << endl;
int flag = 0;
cin >> flag;
if (flag == 1)
{
// 按照编号查询
int id = 0;
cout << “输入查找编号” << endl;
cin >> id;
int find = this->isExist(id);
if (find != -1)
{
cout << “查找成功” << endl;
this->workerArray[find]->showInfo();
}
else
{
cout << “查无此人” << endl;
}
}
else if (flag == 2) {
// 按照姓名查询
string name;
cout << "输入查找的姓名" << endl;
cin >> name;
// 是否查到的标志
bool findFlag = false;
for (int i = 0; i < this->workerNum; i++)
{
if (this->workerArray[i]->name == name) {
cout << " 查询成功,职工编号为: "
<< this->workerArray[i]->id
<< "职工信息如下:" << endl;
// 调用显示
this->workerArray[i]->showInfo();
findFlag = true;
}
}
if (!findFlag)
{
cout << "查找失败" << endl;
}
}
else
{
cout << "输入有误" << endl;
}
}
system("pause");
system("cls");
}
void WorkerManager::sortEmp()
{
if (this->isFileEmpty)
{
cout << “文件为空,或者不存在” << endl;
system(“pause”);
system(“cls”);
}
else
{
cout << “输入排序方式,1.序号升序,2.序号降序” << endl;
int flag = 0;
cin >> flag;
if (flag == 1 || flag ==2)
{
// 升序
for (int i = 0; i < this->workerNum; i++)
{
int minOrMax = i; // 生命最大值或最小值下标
for (int j = i+1; j < this->workerNum; j++)
{
if (flag == 1) // 升序
{
// 如果是升序,当前假设的最大值
if (this->workerArray[minOrMax]->id > this->workerArray[j]->id)
{
minOrMax = j;
}
}
else // 降序
{
if (this->workerArray[minOrMax]->id < this->workerArray[j]->id)
{
minOrMax = j;
}
}
}
// 判断一开始认定的 最大或最小值 是不是 计算得到的最大或最小值,如果不是,交换数据
if (i != minOrMax)
{
Worker \* temp = this->workerArray[i];
this->workerArray[i] = this->workerArray[minOrMax];
this->workerArray[minOrMax] = temp;
}
}
cout << "排序成功,排序后的结果为:" << endl;
this->save();
this->ShowEmp();
}
else
{
cout << "输入有误" << endl;
}
}
}
void WorkerManager::cleanFile()
{
cout << “确定清空?1确定,其他取消” << endl;
int flag = 0;
cin >> flag;
if (flag == 1)
{
// 清空文件
ofstream ofs(FILENAME, ios::trunc); // 删除文件后重建
ofs.close();
if (this->workerArray != NULL)
{
for (int i = 0; i < this->workerNum; i++)
{
delete this->workerArray[i];
this->workerArray[i] = NULL;
}
// 删除堆区指针
delete[] this->workerArray;
this->workerArray = NULL;
this->workerNum = 0;
this->isFileEmpty = true;
}
cout << “清空成功” << endl;
system(“pause”);
system(“cls”);
}
}
WorkerManager::~WorkerManager()
{
if (this->workerArray !=NULL)
{
for (int i = 0; i < this->workerNum; i++)
{
if (this->workerArray[i] !=NULL)
{
delete this->workerArray[i];
}
}
delete[] this->workerArray;
this->workerArray = NULL;
}
}
### 主程序入口
main入口程序,组织相关代码,实现功能
#include
#include
#include “workerManage.h” // 导入头文件
#include “worker.h”
#include “emp.h”
#include “boss.h”
#include “manager.h”
using namespace std;
int main()
{
// 测试代码
Worker* worker = NULL;
worker = new Emp(1, “张三”, 1);
worker->showInfo();
delete worker; // 删除的时new 的时候创建在堆区的数据
worker = new Manager(1, "经理", 2);
worker->showInfo();
delete worker; // 删除
worker = new Boss(1, "老板", 3);
worker->showInfo();
delete worker;
// 实例化管理者对象
WorkerManager wm;
// 用户的选择
int select = 0;
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
三", 1);
worker->showInfo();
delete worker; // 删除的时new 的时候创建在堆区的数据
worker = new Manager(1, "经理", 2);
worker->showInfo();
delete worker; // 删除
worker = new Boss(1, "老板", 3);
worker->showInfo();
delete worker;
// 实例化管理者对象
WorkerManager wm;
// 用户的选择
int select = 0;
[外链图片转存中…(img-QEmNuUf9-1715568881530)]
[外链图片转存中…(img-dU5bM3UB-1715568881530)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新