请教各位前辈如何动态扩展代码


各位前辈周末好,今天我还在加班,无休不止996(常通宵)

现在我做的订单模块,经常需要修改下单部分的代码,可是经常修改这部分的代码对整个订单系统的稳定非常不利。

修改的原因往往是因为促销策略、优惠策略的增加,比如买十送一,买满多少每件商品减多少元等策略

可是我想不到除了修改代码以外更好的方法了,希望各位前辈能指导一下,给点建议意见,谢谢各位前辈了

java 设计模式 head-first设计模式笔记 扩展 面向对象设计模式

阿酱的小内内 8 years, 10 months ago

你这属于活动,你可以把活动抽出来,单独写个通用的活动类,接口什么的,只要每次去配置活动信息就行了

给我眼药水 answered 8 years, 10 months ago

系统内各个模块之间的通信用接口定义,只要保证接口稳定,随便你怎么改模块内部实现

Midori answered 8 years, 10 months ago

说一说我的一点看法:

一、优惠策略有多种形式,但是无论哪种都是在所选购商品种类、数量以及订单金额上做文章,因此可以设计一个通用的过滤器Filter,它接受一个订单(账号、商品号、数量、单价、总价)作为输入,同时返回一个新的订单(账号、商品号、数量、单价、总价、优惠类型),每一个Filter都可以在内部定义一套优惠方案。

二、优惠策略的组合方式有

  1. 可叠加的(买二送一、满500打7折可以同时使用)
  2. 选最有利的(满500减100和会员卡打7折不能同时使用,但是可以选择其中一个使得价格最低)
  3. 互斥的(促销商品不能同时享受满减优惠)

等多种情况。

因此为Filter设计一套组合系统:
每一个Filter内部都可以由其他的Filter组合而成,并有如下几种方式:

  1. 并联(选最大优惠/最小优惠)
  2. 优先级(当多个优惠策略同时满足时,选优先级最高的)
  3. 串联(可以同时使用)

三、针对常见的优惠(如满减、满送、折扣等)做一套模板,可以随时使用参数进行实例化:
例如满减: OffAtFilterFactory(type, off, at) 可以指定type类型商品满at的时候减去off,并产生一个相应的Filter以供使用。
每出现新的优惠,就手动画一画图,把优先级、串并联关系捋清,然后从最内层开始构造Filter,层层嵌套起来(想来也不会超过三层吧)。
之后做一套配置系统,使用XML也好JSON也好,可以直接把优惠写在配置文件里,Filter的生成、组合都由程序读取配置文件后自动进行。
最好的莫过于做一套图形化配置系统,可以通过拖模块画图的方式来写生成配置文件。


实现的话,简单说一下吧,做到手动写Filter还是不难的,至于怎么根据配置文件生成代码,就需要较大篇幅这里就不提了。

看你加了Java话题,我没正经用过Java,就只说一下伪代码哈哈:


 class Order {
    //存储订单的各项信息
}

//这个类要作为一个抽象类
abstract class Filter {

    //构造函数什么的

    //对订单o执行操作
    abstract Order apply(Order o);
}

//这个类是最基础的,非组合式的Filter,也就是说它只能完成一个优惠策略
class PrimitiveFilter extends Filter {

    boolean fit(Order o) {
        //返回o是否符合优惠条件
    }

    Order apply(Order o) {
        //直接对o进行操作,获取订单信息,根据优惠策略生成对应的优惠后的订单并返回
    }
}

class ParallelFilter extends Filter {

    Vector<Filter> pvf;    //pvf按照优先级存储各个Filter

    Boolean fit(Order o) {
        //按照优先级(使用i从0到pvf.length迭代),判断订单o是否符合pvf[i]中的条件(使用fit方法),如果发现符合的,就返回true
        //都不符合返回false
    }

    Order apply(Order o) {
        //按照优先级(使用i从0到pvf.length迭代),判断订单o是否符合pvf[i]中的条件(使用fit方法),如果符合,即返回pvf[i].apply(o)
        //如果不符合,继续判断下一个Filter
        //如果所有的Filter都不符合,返回原订单
    }
}

class SerialFilter extends Filter {
    Vector<Filter> svf;    //按照串联顺序存储Filter(其实这个也没什么顺序可言)

    Boolean fit(Order o) {
        //svf中所有Filter都符合才返回true
        //有一个不符合就返回false
    }

    Order apply(Order o) {
        //按顺序把o通过所有的Filter
        //用Vector的reduce方法就好了,不知道Java里有没有
        //没有的话:
        Order t = o;
        for (Filter f in svf) {
            t = f(t);
        }
        return t;
    }
}

上面这些就足够实现三种优惠组合方案啦。

豆瓣噜大酱 answered 8 years, 10 months ago

Your Answer