博客
关于我
C++学习笔记——(4)基于多态的 职工管理系统
阅读量:600 次
发布时间:2019-03-12

本文共 853 字,大约阅读时间需要 2 分钟。

职工管理系统设计

1、最终效果设计一个职工管理系统,支持对员工信息分类存储与展示,提供增删改查功能,并支持文件存取操作。系统将实现对普通员工、经理、总裁等不同职员信息的管理与操作。

2、实现思路系统将基于面向对象的设计原则,采用封装、继承、多态等概念。通过创建基类Worker,分别派生出EmployeeManagerPresident等具体实现类。基类中定义abstract纯虚函数,实现具体功能的交互。同时创建FileManager类,负责文件操作与管理,实现数据的存取与持久化。

3、需求分析系统功能包含以下选项:0 – 退出系统1 – 增加职工2 – 删除职工3 – 显示所有职工信息4 – 修改职工信息5 – 查找职工6 – 按职工编号排序7 – 清空文档

具体实现细节:

  • 文件操作支持读写追加,确保数据持久化。
  • 支持批量添加多个职工,分类存储。
  • 查询功能支持按编号和姓名双向查找。
  • 排序功能支持升序降序选择。
  • 权限控制设计中路,功能分级待完善。

4、代码主要代码结构如下:«.points: false-->

class Worker {public: abstract void save();   abstract void load();   virtual ~Worker() {}   protected:(vector
data);};class Employee : public Worker {using Worker::save;using Worker::load;private:string name;public:Employee(): Worker() {}void setAge(int age) { ageFactor = age; }};

[file]

上述代码框架定义了核心职工信息处理逻辑,Worker类作为基类提供基本功能支持,其子类Employee实现具体职员处理,后续类如ManagerPresident可按需扩展。

转载地址:http://dqetz.baihongyu.com/

你可能感兴趣的文章
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>