开发,从需求出发 · 之五 麦克斯韦妖

麦克斯韦妖(Maxwell's demon),是在物理学中假想的妖,能探测并控制单个分子的运动,于1871年由英国物理学家詹姆斯·麦克斯韦为了说明违反热力学第二定律的可能性而设想的。


好吧,让我们充当一次麦克斯韦妖,探测和控制单个模块/方法的工作~~~

先上三张图:

传统状态:

1 由于上层接口依赖于下层接口的实现,因此,开发顺序是自下而上开发,底层接口没有实现,上层无法进行有效的开发;

2 SearchService 的测试工作依赖于底层接口的实现,获得的输入不可控,因此在输出存在异常的情况下,无法界定是内部逻辑问题还是输入异常

3 确定输入异常的情况下,需要逐个排查底层接口


模拟状态:

1 由于我们确定 LuceneDAOMock 和 MysqlDAOMock 的运行是正确的,

2 因此LuceneDAO 和 MysqlDAO 的输出也是正确的,

3 SearchService如果逻辑是正确的,那么,其输出也必定是正确的,

4 但是,如果输出不是预期的数值,那么说明,SearchService的实现类 SearchServiceInRealBiz 必定有问题,而且,必定是自身的问题造成的。

5 SearchService接口的实现工作室完全可以和 它所依赖的下一层分离并行的,

6 这种模式下是支持自上而下的开发的——亦即我所说的“从需求出发”


混合状态:

1 混合状态是模拟状态的进行时状态

2 开发过程中,保持其他模块的模拟状态,只选取一个模块进行真实业务逻辑的实现

3 在多个粒度和层面上进行针对该模块的测试

4 将该模块切换为模拟状态,挑选另一个模块重复2-3的开发和测试工作。

5 所有模块实现完毕,同时,也测试完毕。


至此,麦克斯韦妖成功完成了它的工作~~~~


那么,我前面实现的BeanFactory 或者spring 的 依赖注入的作用体现在哪里呢?

——就是 模拟模块和真实模块的注入和切换。

我基于spring.xml的形式说明:


STEP 1,开发和测试 SearchService

SearchService 的实现类: SearchServiceInRealBiz

<?xml version="1.0" encoding="UTF-8"?>
<beans >
        //模拟
	<bean id="luceneDAO" class="cn.com.sitefromscrath.dao.LuceneDAOMock" />
	//模拟
	<bean id="mysqlDAO" class="cn.com.sitefromscrath.dao.MysqlDAOMock" /> 
	
	<bean id="searchService" class="cn.com.sitefromscrath.service.SearchServiceInRealBiz">
		<constructor-arg index="1" ref="luceneDAO" />
		<constructor-arg index="2" ref="mysqlDAO" />
	</bean>  

</beans>

STEP 2, 开发和测试LuceneDAO

<?xml version="1.0" encoding="UTF-8"?>
<beans >
        //开发测试
	<bean id="luceneDAO" class="cn.com.sitefromscrath.dao.LuceneDAOReal" />
	//模拟
	<bean id="mysqlDAO" class="cn.com.sitefromscrath.dao.MysqlDAOMock" /> 
	//模拟
	<bean id="searchService" class="cn.com.sitefromscrath.service.SearchServiceMock">
		<constructor-arg index="1" ref="luceneDAO" />
		<constructor-arg index="2" ref="mysqlDAO" />
	</bean>  

</beans>

STEP 3,开发和测试MysqlDAO

<?xml version="1.0" encoding="UTF-8"?>
<beans >
        //模拟
	<bean id="luceneDAO" class="cn.com.sitefromscrath.dao.LuceneDAOMock" />
	//开发测试
	<bean id="mysqlDAO" class="cn.com.sitefromscrath.dao.MysqlDAOReal" /> 
	//模拟
	<bean id="searchService" class="cn.com.sitefromscrath.service.SearchServiceMock">
		<constructor-arg index="1" ref="luceneDAO" />
		<constructor-arg index="2" ref="mysqlDAO" />
	</bean>  

</beans>

开发测试同步完成。


不仅仅开发如此,在以后的系统维护过程中,一旦发生异常,是比较容易排查错误的原因的,如果你能获得真实环境下的异常输入,那么,debug将会相当快速高效。

你所要做的只不过是像麦克斯韦妖一样——把不同的分子放到不同的格子里面去

我确信,当我启动tomcat,打开页面,并进行查询操作的时候,得到的页面展示内容是正确的,符合预期的:)


OK了:)

基于sitefromscratch这个搜索网站项目的讨论到此结束,在接下来的章节里,我打算引申到更广泛的领域里面去。

to be continued.............

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值