您在Java项目中使用什么策略进行包命名?为什么?
我刚才考虑过这个问题,最近我的商店正在制作它的第一个真正的
Java网络应用程序.
作为介绍,我看到两个主要的包命名策略. (要清楚,我不是指整个’domain.company.project’的一部分,我在谈论它下面的包约定.)无论如何,我看到的包命名约定如下: >功能:根据业务领域,根据其功能在架构上命名您的包,而不是其身份.另一个术语可能是根据’layer’命名.所以,你有一个* .ui包和一个* .domain包和一个* .orm包.您的包是水平切片而不是垂直切片. 这比逻辑命名更常见.事实上,我不相信我曾经见过或听说过这样做的项目.这当然让我很害羞(有点像认为你已经想出了NP问题的解决方案),因为我不是非常聪明,我认为每个人都必须有充分的理由按照他们的方式去做.另一方面,我并不反对人们只是错过了房间里的大象,而且我从来没有听到过以这种方式进行包装命名的实际论点.它似乎是事实上的标准. 正如我之前提到的,我从未见过或听说过这一点,但这对我来说很有意义. >我倾向于垂直接近系统而不是水平接近系统.我想进入并开发订单处理系统,而不是数据访问层.显然,我很有可能在该系统的开发中触及数据访问层,但重点是我不这么认为.当然,这意味着当我收到变更单或者想要实现一些新功能时,不必为了找到所有相关的类而不必在一堆包中钓鱼.相反,我只是查看X包,因为我正在做的与X有关. 所以我想那个问题会告诉你,你如何命名你的包裹以及为什么?请理解我并不一定认为我偶然发现了金鹅或其他东西.我对这一切都很陌生,主要是学术经历.但是,我无法发现我的推理中的漏洞,所以我希望你们都能这样,以便我能继续前进. 解决方法
对于包装设计,我首先按层,然后通过一些其他功能.
还有一些额外的规则: >层从最常见(底部)到最具体(顶部)堆叠 因此,对于Web应用程序,您可以在应用程序层中具有以下层(从上到下): >表示层:生成将在客户端层中显示的UI 对于生成的包布局,这些是一些额外的规则: >每个包名的根目录是< prefix.company>.< appname>.< layer> 这是一个示例布局. 表示层由视图技术划分,并且可选地由(组)应用划分. com.company.appname.presentation.internal com.company.appname.presentation.springmvc.product com.company.appname.presentation.servlet ... 应用程序层分为用例. com.company.appname.application.lookupproduct com.company.appname.application.internal.lookupproduct com.company.appname.application.editclient com.company.appname.application.internal.editclient ... 服务层分为业务域,受后端层中的域逻辑的影响. com.company.appname.service.clientservice com.company.appname.service.internal.jmsclientservice com.company.appname.service.internal.xmlclientservice com.company.appname.service.productservice ... 集成层分为“技术”和访问对象. com.company.appname.integration.jmsgateway com.company.appname.integration.internal.mqjmsgateway com.company.appname.integration.productdao com.company.appname.integration.internal.dbproductdao com.company.appname.integration.internal.mockproductdao ... 分离这样的软件包的优点是管理复杂性更容易,并且提高了可测试性和可重用性.虽然看起来很多开销,但根据我的经验,它实际上非常自然,每个人都在这个结构(或类似的)上工作,在几天内就可以完成. 为什么我认为垂直方法不是那么好? 在分层模型中,几个不同的高级模块可以使用相同的低级模块.例如:您可以为同一个应用程序构建多个视图,多个应用程序可以使用相同的服务,多个服务可以使用相同的网关.这里的技巧是,当在层中移动时,功能级别会发生变化.更具体层中的模块不会在更一般的层上映射模块上的1-1,因为它们表达的功能级别不映射1-1. 当您使用垂直方法进行包装设计时,即首先按功能划分,然后将具有不同功能级别的所有构建块强制插入到相同的“功能夹克”中.您可以为更具体的模块设计通用模块.但是这违反了更普遍的层不应该知道更具体的层的重要原则.例如,服务层不应该在应用层的概念之后建模. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |