Alan 2020-6-2 10:01
在并多的案例中,计算价钱由拼单子订单完成,拼单子订单有数量,就能计算价格,实际上计算价格影响的因子比较多,比如价格,2件以上再打9.5折,顾客类型(高级会员),在总价高于200时还能再0.95折,还有不同的包邮类型决定最后价格,针对并多多的计算价格,采用面向对象来设计,合适的做法有
A. 提供一个计算价格的类 feeCount ,把所有参数传给这个类去算,后续有变更规则,只需要修改此类的逻辑即可
B. 仍在拼单子订单计算,把顾客对象,商品对象的类传入子订单
C. 顾客类型,订单,包邮类型 都有计算价格的接口,根据自己的规则对传入价格再计算一次
D. 放在控制类,从各个对象取出属性,再按规则计算
子订单计算价钱是专家原则么?
如同这里,计算租金的规则也很复杂,只是设备规格搞不定,是否也给设备规格算?
很多采集面向对象,最像就在一个service 把其它对像的属性get出来,然后算一把,能封装修改点,确定也算逻辑内聚,但是在责任分配上确实又不是面向对象
UMLChina潘加宇
凡是“规则很复杂”,需要一个“service”来封装一个“算法”的,很有可能是类图还画得不够细,还得继续剖析背后的知识,而不是藏在“算法”里面
“实际上计算价格影响的因子比较多,比如价格,2件以上再打9.5折,顾客类型(高级会员),在总价高于200时还能再0.95折,还有不同的包邮类型决定最后价格”---这些都要通过类图表达出来
另外,计算价钱之类实际上仍然属于查询,并没有修改对象的状态,所以责任怎么分配,其实问题不大。面向对象的用处主要是,修改数据时能通过状态机维护逻辑的完整性
Alan
嗯,但这个的变动点比较多,较好的封装规则易于维护,也不容易出错。计算出错对业务的影响比较大
UMLChina潘加宇
所以就要通过类图把各个概念之间的关系精细表达出来,而不是搞一个“**计算器”,然后就以为万事大吉了
Alan
系统增加了规则(现实中规则可能更复杂),这几个新增的价格描述规则是否准确,计算价格时实际涉及多个类,放哪个类都需要了解其它类封装规则 ?
还有这一步,用户提交拼单信息,系统验证拼音信息,需要包含商品价格是否对,是不是与前面一步反馈的信息相同,这种考虑是否属于分析工作流内容
UMLChina潘加宇
“决定邮费”那里不够,另外邮费的标准应该不会精细到某个商品,而是商品类别。
关系:商品-商品类别-邮费标准-区域。
商品折扣那里应该是价格区间(单价、数量下限,数量上限)
是否属于分析工作流内容 --把系统的对象看作是在大脑里运行,对象的创建、修改速度无限快,然后你担心的“问题”“逻辑”还存在吗?
如果还存在--那就是分析问题
如果消失了--那就是设计问题
这个区分很重要,因为分析和设计的映射是有规律的,区分好了,人脑要应对的复杂度是m+n,区分不好,就是m×n
例如:商品价格是否对--如果担心的是因为系统的分布问题,造成界面的信息、内存里对象的信息、持久存储里数据的信息有时会不一致,所以要验证一下,那么这个问题在上面的测试中,属于会消失的问题,那是设计问题。而这个设计问题,不只是对商品存在,对顾客、发票、订单等等都存在一模一样的问题,如果不区分,就会在各个地方一遍一遍的重复这样的“逻辑”和“技巧”。