• 第十一周作业


    Cola公司的雇员分为以下若干类:(知识点:多态)

    (1) ColaEmployee :这是所有员工总的父类,属性:员工的姓名,员工的生日月份。

    • 方法:getSalary(int month) 根据参数月份来确定工资,如果该月员工过生日,则公司会额外奖励100 元。

    (2) SalariedEmployee :     ColaEmployee 的子类,拿固定工资的员工。

    • 属性:月薪

    (3) HourlyEmployee :ColaEmployee 的子类,按小时拿工资的员工,每月工作超出160 小时的部分按照1.5 倍工资发放。

    • 属性:每小时的工资、每月工作的小时数

    (4) SalesEmployee :ColaEmployee 的子类,销售人员,工资由月销售额和提成率决定。

    • 属性:月销售额、提成率

    (5) 定义一个类Company,在该类中写一个方法,调用该方法可以打印出某月某个员工的工资数额,写一个测试类TestCompany,在main方法,把若干各种类型的员工放在一个ColaEmployee 数组里,并单元出数组中每个员工当月的工资。

    package method;
    
    public class ColaEmployee {
        String name;
        int month;
    
        public ColaEmployee() {
    
        }
    
        public ColaEmployee(String name, int month) {
            super();
            this.name = name;
            this.month = month;
        }
    
        public double getSalary(int month) {
            return 0;
        }
    }
    package method;
    
    public class salariedEmployee extends ColaEmployee{
         double salary;
            public salariedEmployee() {
                super();
            }
            public salariedEmployee(String name, int month,int salary) {
                super(name,month);
                this.salary = salary;
            }
            public double getSalary(int month) {
                if (super.month == month) {
                    return salary + 100;
                }else {
                    return salary;
                }
            }
            
        }
    package method;
    
    public class hourlyEmployee extends ColaEmployee {
        private int hourlysalary;
        private int hourlytime;
    
        public hourlyEmployee() {
            super();
        }
    
        public hourlyEmployee(String name, int month, int hourlytime, int hourlysalary) {
            super(name, month);
            this.hourlytime = hourlytime;
            this.hourlysalary = hourlysalary;
        }
    
        public double getHourlysalary(int month) {
            if (super.month == month) {
                if (hourlytime > 160) {
                    return hourlysalary * 160 + hourlysalary * (hourlytime - 160) * 1.5 + 100;
                } else {
                    return hourlysalary * hourlytime + 100;
                }
            } else {
                if (hourlytime > 160) {
                    return hourlysalary * 160 + hourlysalary * (hourlytime - 160) * 1.5;
                } else {
                    return hourlysalary * hourlytime;
                }
            }
    
        }
    
    }
    package method;
    
    public class salesEmployee extends ColaEmployee {
        private int monthSales;
        private double royaltyRate;
    
        public salesEmployee(String name, int month, int monthSales, double royaltyRate) {
            super(name, month);
            this.monthSales = monthSales;
            this.royaltyRate = royaltyRate;
        }
    
        public double getSalary(int month) {
            if (super.month == month) {
                return monthSales * royaltyRate + 100;
            } else {
                return monthSales * royaltyRate;
            }
        }
    
    }
    package method;
    
    public class company {
        public void getSalary(ColaEmployee c, int month) {
            System.out.println(c.name + "在" + month + "月的月薪为" + c.getSalary(month) + "元");
        }
    }
    package method;
    
    public class testCompany {
    
        public static void main(String[] args) {
            // TODO Auto-generated method stub
    
            ColaEmployee[] all = { new salariedEmployee("张三", 4, 10000), 
                    new hourlyEmployee("李四", 4, 10, 30), 
                    new salesEmployee("王五", 4, 5000, 0.3)
            };
            for (int i = 0; i < all.length; i++) {
                new company().getSalary(all[i], 5);
            }
        }
    
    }
  • 相关阅读:
    游戏架构草稿(1)
    蔡学镛:架构师最重视的文档
    常见拉丁字母
    图像识别学习1
    .net framework 2.0,3.0与3.5之间的关系 [转载]
    ASP.NET Session丢失问题原因及解决方案[转载]
    PLSQL 循环游标 cursor loop fetch into【转载】
    oracle case when的用法 【转载】
    Oracle to_char格式化函数 [转载]
    oracle表关联应用 【转载】
  • 原文地址:https://www.cnblogs.com/qsf1975747------/p/12915120.html
Copyright © 2020-2023  润新知