网文提到表格驱动,总喜欢拿一层if做例子,然而这样未免也太简单.

下文是三层缩进的if和表驱动比较,大家可自行判断优劣.

业务是这样的,某景点分旺季票价和淡季票价,淡季票为旺季的一半,15岁以下孩子再减半,60岁以上老人再三三折,成人中有军官证的再打二五折,有士兵证的打两折.(假定非实际业务,勿对号入座)

代码:

package tabledriven;

/**
 *   门票计价器
 * 传统方式和表格驱动比较
 *
 */
public class TicketCalculater {
    // Price
    private double price=144;

    // discout array
    private int[][][] arr= {
                                {
                                    {2*4,2*5,2*1},
                                    {2*2,2*2,2*2},
                                    {2*3,2*3,2*3},
                                },
                                {
                                    {1*4,1*5,1*1},
                                    {1*2,1*2,1*2},
                                    {1*3,1*3,1*3},
                                },
                           };

    // Traditional
    public double getPriceTraditional(int month,Person person) {
        double discount=1;

        if(6<month && month<11) {
            discount*=1;

            if(person.getAge()<15) {
                discount*=0.5;
            }else if(person.getAge()>60) {
                discount*=0.33333333333333;
            }else {
                if(person.isOfficer()) {
                    discount*=0.25;
                }else if(person.isSoldier()) {
                    discount*=0.20;
                }
            }
        }else {
            discount*=0.5;

            if(person.getAge()<15) {
                discount*=0.5;
            }else if(person.getAge()>60) {
                discount*=0.333333333333333;
            }else {
                if(person.isOfficer()) {
                    discount*=0.25;
                }else if(person.isSoldier()) {
                    discount*=0.20;
                }
            }
        }

        return price*discount;
    }

    // Table driven
    public double getPriceTableDriven(int month,Person person) {
        double discount=1;

        int index1,index2,index3;

        if(6<month && month<11) {
            index1=1;
        }else {
            index1=0;
        }

        if(person.getAge()<15) {
            index2=1;
        }else if(person.getAge()>60) {
            index2=2;
        }else {
            index2=0;
        }

        if(person.isOfficer()) {
            index3=0;
        }else if(person.isSoldier()) {
            index3=1;
        }else {
            index3=2;
        }

        discount=arr[index1][index2][index3];

        return price/discount;
    }

    // Entry point
    public static void main(String[] args) {
        TicketCalculater tc=new TicketCalculater();

        Person p1=new Person(30,false,false);
        System.out.println("Ticket price="+round2DecimalPlaces(tc.getPriceTraditional(2, p1)));
        System.out.println("Ticket price(Table)="+round2DecimalPlaces(tc.getPriceTableDriven(2, p1)));

        Person p2=new Person(14,false,false);
        System.out.println("Ticket price="+round2DecimalPlaces(tc.getPriceTraditional(5, p2)));
        System.out.println("Ticket price(Table)="+round2DecimalPlaces(tc.getPriceTableDriven(5, p2)));

        Person p3=new Person(44,true,false);
        System.out.println("Ticket price="+round2DecimalPlaces(tc.getPriceTraditional(8, p3)));
        System.out.println("Ticket price(Table)="+round2DecimalPlaces(tc.getPriceTableDriven(8, p3)));

        Person p4=new Person(68,false,true);
        System.out.println("Ticket price="+round2DecimalPlaces(tc.getPriceTraditional(11, p4)));
        System.out.println("Ticket price(Table)="+round2DecimalPlaces(tc.getPriceTableDriven(11, p4)));
    }

    // round two decimal places of a double
    public static String round2DecimalPlaces(double d){
        java.text.DecimalFormat df =new java.text.DecimalFormat("#0.00");
        return df.format(d);
    }
}

Person类:

package tabledriven;

public class Person {
    private int age;
    private boolean isOfficer;
    private boolean isSoldier;

    public Person(int age,boolean isOfficer,boolean isSoldier) {
        this.age=age;
        this.isOfficer=isOfficer;
        this.isSoldier=isSoldier;
    }

    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public boolean isOfficer() {
        return isOfficer;
    }
    public void setOfficer(boolean isOfficer) {
        this.isOfficer = isOfficer;
    }
    public boolean isSoldier() {
        return isSoldier;
    }
    public void setSoldier(boolean isSoldier) {
        this.isSoldier = isSoldier;
    }
}

运行结果:

Ticket price=72.00
Ticket price(Table)=72.00
Ticket price=36.00
Ticket price(Table)=36.00
Ticket price=36.00
Ticket price(Table)=36.00
Ticket price=24.00
Ticket price(Table)=24.00

--END-- 2019-12-11 14:01

多层If语句 和 表格驱动 的对比的更多相关文章

  1. Linux与Windows的设备驱动模型对比

    Linux与Windows的设备驱动模型对比 名词缩写: API 应用程序接口(Application Program Interface ) ABI 应用系统二进制接口(Application Bi ...

  2. JS010. 三元运算符扩展运用(多层判断语句 / 多条表达式)

    MDN - 三元运算符 语法 Condition ? exprIfTrue : exprIfFalse 用例: function getFee(isMember) { return(isMember ...

  3. 任务驱动,对比式学习.NET开发系列之开篇------开源2个小框架(一个Winform框架,一个Web框架)

    一 源码位置 1. Winform框架 2. web框架 二 高效学习编程的办法 1 任务驱动方式学习软件开发 大部分人学习软件开发技术是通过看书,看视频,听老师上课的方式.这些方式有一个共同点即按知 ...

  4. 4 - SQL Server 2008 之 使用SQL语句删除表格

    使用删除表格的SQL命令与删除数据的命令一样,只是删除的是表格这个对象, 语法如下:DROP TABLE 表名 一般在删除表格之前,需判断这个表格存不存在,存在则删除,不存在则不进行执行任何代码. 代 ...

  5. golang的表格驱动测试

    一.leetcode的算法题 package main import ( "fmt" "strings" ) func lengthOfNonRepeating ...

  6. [转帖]Docker五种存储驱动原理及应用场景和性能测试对比

    Docker五种存储驱动原理及应用场景和性能测试对比 来源:http://dockone.io/article/1513 作者: 陈爱珍 布道师@七牛云   Docker最开始采用AUFS作为文件系统 ...

  7. python init 方法 与 sql语句当前时间对比

    def init(self,cr): tools.sql.drop_view_if_exists(cr, 'custrom_product_infomation_report') cr.execute ...

  8. Docker存储驱动之OverlayFS简介

    简介 OverlayFS是一种和AUFS很类似的文件系统,与AUFS相比,OverlayFS有以下特性: 1) 更简单地设计: 2) 从3.18开始,就进入了Linux内核主线: 3) 可能更快一些. ...

  9. python中if语句和循环语句

    //2019.12.05 python循环控制结构(一)控制循环结构 1-1 程序的判断语句与组合1.对于python的控制结构主要有以下三大类:(1)分支结构(2)循环结构(3)异常处理 2.pyt ...

随机推荐

  1. SQL SERVER-AlwaysonResolving

    虽然2台都是同步提交,自动failover模式 在辅助副本的AG中先删掉一个可用DB,然后关闭主副本,之后辅助副本变为下图.不能自动failover. 重新开启主副本后,主副本显示一切正常 但是辅助副 ...

  2. SQL PLUS 远程连接数据库

    -- SQL PLUS 远程连接Oracle数据库(WINDOWS+SQL PLUS)命令:用户名/密码@ip地址[:端口]/service_name [as sysdba] EG: ORCL/ORC ...

  3. Linux在丢失的情况下重置密码

    1.开机菜单是 移动光标到第一行 --敲击e 2.找到UTF-8,加上空格rd.break,敲击ctrl+x 3.输入以下命令 mount -o remount,rw /sysroot chroot ...

  4. Makefile学习二

    今天继续对Makefile进行研究,话不多说,进入正题: make常用内嵌函数: 下面利用上面的知识点来实现一个多级目录的Makefile,如下: 多级目录Makefile: 这个例子的目录结构如下: ...

  5. 微信小程序~调试

    小程序调试面板 模拟器 模拟器模拟微信小程序在客户端真实的逻辑表现,对于绝大部分的 API 均能够在模拟器上呈现出正确的状态. 自定义编译 点击工具栏中的编译按钮或者使用快捷键 Ctrl(⌘) + B ...

  6. 学习markdown(一)

    转:https://www.jianshu.com/p/81e1608ea2d8 ----------------------------------------------------------- ...

  7. react 学习记录

    1.  脚手架搭建项目  create-react-app https://www.jianshu.com/p/d196761c8332 2. UI框架 https://ant.design/docs ...

  8. dedecms自定义表单提交获取时间跟ip地址

    相信大家在用织梦做网站的时候都用过自定义表单做留言,但是如何查看客户什么时间填写的表单,和客户的IP地址呢? 我在网上找了很多JS文件,但太繁琐了,后来我注意到一个细节,每次我登陆后台,织梦系统都会记 ...

  9. Yarn节点及作用

    1.yarn中的角色:ResourceManager.NodeManager.ApplicationMaster. ResourceManager:集群计算资源的分配,启动ApplicationMas ...

  10. 使用Default Trace查看谁还原了你的数据库?

    select e.nameaseventclass,t.loginname,t.spid,t.starttime, t.textdata,t.objectid,t.objectname,t.datab ...