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

练习写一个工资结算系统

要求:公司将职员分为三类:部门经理、技术员和销售员。在发工资的时候,部门经理拿固定月薪8000元,技术人员按每小时100元领取月薪,销售人员按照500元底薪加当月销售额的4%进行提成,设计并实现一个工资结算系统。

思路:先创建一个所有员工共有属性和方法的员工类,在创建继承了员工类的经理、技术员和销售员子类,实现调用一种方法就能根据类得到不同结果。

代码如下:

package mt.wage;
/**
 * 员工类
 * @author mt
 *
 */
public abstract class Employee {
    protected String name;
    protected String pasition;
    
    
    public abstract int getSalary() ;

    public String getName() {
        return name;
    }

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

    public String getDepartment() {
        return pasition;
    }

    public void setDepartment(String department) {
        this.pasition = department;
    }
    
    
}
package mt.wage;
/**
 * 经理类
 * @author mt
 *
 */
public class Manager extends Employee {
    public Manager(String name) {
        this .name = name;
        this.pasition = "经理";
    }
    @Override
    public int getSalary() {    
        return 8000;
    }
}
package mt.wage;
/**
 * 技术员类
 * @author mt
 *
 */
public class Programmer extends Employee {
    private int workTime;
    
    public Programmer(String name , int workTime) {
        this.name = name;
        this.workTime = workTime;
        this.pasition = "技术员";
    }
    
    public int getWorkTime() {
        return workTime;
    }
    public void setWorkTime(int workTime) {
        this.workTime = workTime;
    }

    @Override
    public int getSalary() {
        return 100 * workTime;
    }

}
package mt.wage;
/**
 * 销售员类
 * @author mt
 *
 */
public class Salesman extends Employee {
    private int sales;
    
    public Salesman(String name ,int sales) {
        this.name = name;
        this.sales = sales;
        this.pasition = "销售员";
    }
    @Override
    public int getSalary() {
        return 1200 + sales * 5/100;
    }

}
package mt.wage;

public class Test {
    public static void main(String[] args) {
        Employee[] em ={
                new Manager("张三"),
                new Programmer("李斯", 100),
                new Salesman("王五", 5000),
                new Programmer("赵钱", 50),
                new Salesman("孙犁", 10000),
                new Salesman("麻子", 8000)
                
        };
        for (Employee x :em) {
        System.out.println(x.pasition + x.name 
                + "的"+ "工资为:" + x.getSalary());
        }
    }
}

072222063928867.png

转载于:https://www.cnblogs.com/mt1500/p/4486310.html

相关文章:

  • linux的各个子系统
  • 域名注冊以及域名解析设置
  • 约瑟夫环实现之非递归
  • 微信公众号-开发者-自定义菜单-CLICK事件处理
  • “我爱淘”冲刺阶段Scrum站立会议6
  • 我们还需要兼容IE样式问题吗?
  • modernizr框架之表单验证
  • jquery easyUI DataGrid 初始化的时候就显示可排序的字段
  • 从顺序查找窥探平均时间复杂度分析的一般化方法
  • 无法升级数据库....因为此版本的 SQL Server 不支持该数据库的非发布版本(539) 解决方案...
  • SSIS 2012 Error: An Integration Services class cannot be found
  • JVM 内存模型
  • 机器视觉(4)——视觉系统基本组成
  • bzoj 1012 [JSOI2008]最大数maxnumber
  • 模拟数组的sort排序方法
  • angular2开源库收集
  • Js基础知识(四) - js运行原理与机制
  • leetcode46 Permutation 排列组合
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • vuex 学习笔记 01
  • 对象引论
  • 解决iview多表头动态更改列元素发生的错误
  • 400多位云计算专家和开发者,加入了同一个组织 ...
  • #pragma pack(1)
  • (16)Reactor的测试——响应式Spring的道法术器
  • (33)STM32——485实验笔记
  • (附源码)python旅游推荐系统 毕业设计 250623
  • (附源码)ssm基于jsp的在线点餐系统 毕业设计 111016
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (力扣记录)235. 二叉搜索树的最近公共祖先
  • **PHP二维数组遍历时同时赋值
  • *p=a是把a的值赋给p,p=a是把a的地址赋给p。
  • .net on S60 ---- Net60 1.1发布 支持VS2008以及新的特性
  • .net快速开发框架源码分享
  • .net中应用SQL缓存(实例使用)
  • @FeignClient注解,fallback和fallbackFactory
  • @html.ActionLink的几种参数格式
  • [BUUCTF NewStarCTF 2023 公开赛道] week4 crypto/pwn
  • [BZOJ 1040] 骑士
  • [bzoj2957]楼房重建
  • [C++]类和对象【上篇】
  • [CareerCup][Google Interview] 实现一个具有get_min的Queue
  • [dfs] 图案计数
  • [Docker]十一.Docker Swarm集群raft算法,Docker Swarm Web管理工具
  • [EWS]查找 文件夹
  • [github配置] 远程访问仓库以及问题解决
  • [Java安全入门]三.CC1链
  • [k8s系列]:kubernetes·概念入门
  • [Linux] Apache的配置与运用
  • [MAC OS] 常用工具
  • [MSSQL]GROUPING SETS,ROLLUP,CUBE初体验
  • [ORM]register db Ping `default`, Error 1130: Host '' is not allow connect to this MySQL server
  • [Servlet 4]Bean与DAO设计模式