`
raymond.chen
  • 浏览: 1441463 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

在项目架构中如何进行分层才是最合理的?

    博客分类:
  • Java
阅读更多

     目前很多项目在框架搭建时都遵循以下的分层关系:View层、Action层、Service层、Dao层。在Service层和Dao层中,一个接口文件对应一个实现类,无论是大项目还是小项目,都按照这个模式去做,说这是软件架构的标准做法。本人觉得,一个接口文件对应一个实现类这样做有很多缺点:

     1)创建的文件数量太多。

     2)增加了开发人员的工作量。

     3)增加了后期维护的复杂性。

     4)程序调试不方便。

其实,Service层和Dao层的接口文件完全可以去掉的,只需要具体类就可以了,而且Dao层也不是必须的,可以作为可选层来处理。当Service层的一些方法需要在多个地方引用时,才增加Dao层,用于存放这些公共方法。

 

     SpringSide就是这样做的,不知道大家的看法如何?

  • 大小: 44.1 KB
  • 大小: 30.7 KB
分享到:
评论
115 楼 uptorun 2009-07-29  
dao层次是有必要存在的, 至少可以保证数据库代码的充用与屏蔽 .
大多数的业务层代码比较简单,但是对事物的控制时抽象Service的
重要理由,但是好像没有必要一个实体一个Service,我的做法通常是
一个业务模块一个Service借口.
114 楼 h521999 2009-07-28  
个人认为,应该看项目大小而定,如果项目小的完全可以无需接口。
113 楼 lin23871 2009-07-28  
yangwudong 写道
低耦合,高复用
就这六个字,足够解释的了


还是那句话:效率怎么保证?
112 楼 lin23871 2009-07-28  
zhenjia 写道
你给我的感觉就是觉得service 和dao 没必要同时存在,没必要去对应那些接口。
dao,和数据直接打交道
service,通过dao实现业务逻辑
你可直接实现动态dao
那样的话你就只剩下service了
http://www.iteye.com/topic/232885类似我实现的这样


那效率呢?比直接操作sql效率地很多,hibernate本身效率就不高!
111 楼 lin23871 2009-07-28  
liuqiang 写道
据我的理解,分层的好处在于:

1 团队协作,一个组负责一个层,一个人负责该层的若干个点

2 可扩展性,一个接口可以有多个实现,在大点的项目里这个是很常见的,对于中小型的web来说,还是php rails来的爽

3 可维护性,哪个层出了问题就去哪个层解决



“一个接口可以有多个实现,在大点的项目里这个是很常见的”,举例说明下
110 楼 lin23871 2009-07-28  
downpour 写道
在任何时候,请使用面向接口的编程方式,尤其在项目不断膨胀的过程中,针对接口的编程会为你带来无穷的好处。


什么好处??请说出来
109 楼 WithMemores 2008-10-21  
个人感觉,层的目标主要是降低复杂性和耦合度。
层粉的多了,每个层需要处理的东西就少了。需求因为接口就抽象起来了,
容易变更和维护。
不过,事实上,因为层的增多,需要抽象的组件越多。代码越多。处理的功能过于集中和局部。不很容易明白整体的处理方式,或者说要求的起点太高。如果在大多数时间做的都是不大的项目。那么使用起来纯属找虐。
对Hibernate的部分观点。Hibernate处理的是数据库解耦。如果不引入DAO接口
要Hibernate干吗?
108 楼 liuwei1981 2008-10-11  
项目不大,功能不复杂的话,感觉像rails一样,设置一个controller放action,一个service放service方法,model放模型类,比较好,如果功能负责,就得按照业务分包了。
107 楼 lxlzhn 2008-10-10  
mingo 写道
适合的就是最好的。标准做法只能说是参考。

同意!标准就是用来衡量的,不是用来实际操作的。
106 楼 forever_jenova 2008-10-08  
还是喜欢接口+实现类~
105 楼 lin5061 2008-10-05  
我认为DAO层大多数情况下都有它存在的必要 除非你的业务真的是写一次就定死了 而且业务太简单。原因是:
1.的确hibernate提供了很方便的接口了,而且spring更是将dao操作封装得淋漓尽致,但是当你突然想加一个业务相关的dao方法给许多service用的时候 你咋办呢?
2.框架只需要提供一个DAO即可,这样基本上就只会多出两个文件:一个是DAO接口 一个是DAO实现类。这个实现类继承第三方的就行,比如hibernate或spring提供的。如果再有其它添加方法可以在这里自定义。毕竟你可以这么认为:hibernate和spring所提供的操作基本都是原子性的,如果需要一点点业务色彩的方法就得自己写了(当然这不是业务类。)
104 楼 xyf_84 2008-10-05  
概念不清还在这里讨论
103 楼 laodizhuq 2008-10-04  
适合的就是最好的,如果是大型项目,分层和接口都非常重要。
接口可以更方便的多人合作开发,只要事先吧接口写好,各自就可以写自己的代码,而不用等待别人的代码完成了才可以调试测试。你可以自己写一个简单的接口实现直接返回true,然后来测试自己的代码,不用等待。
对于分成的多少完全要看应用,我们公司的应用还把service层拆开来做两层。因为根据我们的业务需求把所有的业务逻辑都放在一层里面,会导致service层非常庞大,不利于维护,所以我们允许在service层之上再写一层,比如专门控制流程。service层就实现每个节点的功能。
102 楼 summerbell 2008-10-03  
godoo 写道
我做了多年的软件开发,从我的经历来讲讲我的意见,首先,看看你所说的采用接口的缺点吧
1. 创建的文件数量太多--你做的项目多大,占用了多少开发工作量?请统计一下自己的工作内容和时间,从我的经验看,这个问题几乎可以忽略
2. 增加了开发人员的工作量--同问题1,如果采用自动生成接口文件,那工作量就更少到忽略了
3. 增加了后期维护的复杂性--本质同1
4. 程序调试不方便--有一定道理,但我的情况来看,也不困难;还有些插件可以帮助找到接口的具体实现

优点说个体会最深的
1. 如果你自己写测试(特别是如果你是TDD爱好者),你会体验到接口的威力
2. 接口的确会使你的应用灵活很多;DAO改变实现很少,不管是换DB,还是换框架或实现,业务层换具体实现也不太多,但你测试时会方便很多(这个所有都适用);
其他优点还有不少,可以参考如敏捷软件开发之类的书籍


1. 如果你自己写测试(特别是如果你是TDD爱好者),你会体验到接口的威力
---------
能具体展开说一下么?
101 楼 z494627 2008-10-02  
分层本来就是为了灵活,使用接口也是为了应付变化。不要说迁移持久层的实现,就是客户的一些临时的需求变化,也会导致程序很多地方变动。软件就是要应付变化!
100 楼 williamou 2008-09-30  
guoping007 写道
mingo 写道
适合的就是最好的。标准做法只能说是参考。

就我个人理解,作三层的目的最大的作用是消除重复代码,同时使项目更容易理解和扩展,当然也有很多教科书的说法,比如说移植性,但实际上真正有用的就是消除重复代码。
  另外对于接口的看法,看项目了,如果项目较小,不用接口没什么影响,如果项目比较复杂,接口还是能带来很多好处的。


很同意楼上的说法。。
要不要分层,分多少层应该以项目的具体情况而定
99 楼 xugq035 2008-09-30  
接口还是需要的,为什么一定要区分大项目和小项目?小项目随着需求的不断增加和修改也会转化成大项目,除非你认为自己做出来的应用没有进步的意义。
dao一般是一个表对应一个,当然也存在操作多个表或者直接执行原生sql;service通常是调用多个dao去处理事务,并不是一个service只能调用一个dao
我现在的做法是action中既调用service也调用dao,一些简单的查询直接调用dao就可以执行,没必要在service中重复一次;一些复杂的事务或者可能在多个action中都调用的方法都放在service中实现
98 楼 wopenonline111 2008-09-29  
downpour 写道
在任何时候,请使用面向接口的编程方式,尤其在项目不断膨胀的过程中,针对接口的编程会为你带来无穷的好处。



强烈怀疑在小项目中使用接口所带来的好处,5,6万行规模的项目使用接口恐怕带来的收益不能抵消其所增加的成本。
97 楼 neptune 2008-09-29  
在做项目时,问心自问,你的Service接口有几个实现,你的Dao接口有几个实现。分层是必要的,但每个Service和Dao都只有其对应的,一个Interface和一个Implement,那还有意义吗
96 楼 wzybadboy 2008-09-28  
个人觉得应该有dao和service,接口也是必要的,首先是从面向接口编程的角度来讲,其次接口可以去掉重复的代码,降低代码的耦合度。像上面说的可以在service层调用dao侧的实现方法,也不会增加太多的代码量,实现的代码结构清晰,耦合度低。

相关推荐

    基于的.net的分层架构

    在IT行业中,构建高效、可扩展且易于维护的软件系统是至关重要的。基于.NET的分层架构是一种常用的设计模式,...阅读“基于.NET平台的分层架构实战.pdf”这样的资料,可以帮助你更深入地理解如何在实践中应用这些概念。

    DotNet分层

    在IT行业中,分层架构是一种常见的软件设计模式,它将复杂的应用程序分解为多个相互独立、职责明确的层次。在DotNet开发环境中,分层架构是实现可维护性、可扩展性和可重用性的关键策略。本文将深入探讨DotNet分层...

    项目架构思想

    在IT行业中,项目架构思想是构建复杂软件系统的关键要素,它涉及到如何组织和设计软件的各个部分,以实现高效、可扩展和易于维护的目标。本文将深入探讨项目架构的几个核心概念,结合“源码”和“工具”的标签,我们...

    C#分层思想之实例项目详解

    总的来说,C#分层思想是软件工程中的重要概念,通过合理划分各层,可以使项目更易于管理,提高开发效率。在实际项目中,根据需求和团队规模,还可以考虑添加其他层次,如服务层、缓存层等,以优化系统性能和架构。

    02-架构分层:我们为什么一定要这么做?_For_group_share1

    在软件开发领域,架构分层是一种常见的设计模式,它有助于管理和组织复杂的系统结构,确保代码的可读性、可维护性和可扩展性。当我们谈论"02-架构分层:我们为什么一定要这么做?"时,这个问题的核心在于理解分层...

    基于WCF的项目架构

    在本文中,我们将深入探讨基于WCF的项目架构,以及如何利用其特性构建高效、可扩展的服务。 **一、WCF基础概念** 1. **服务**: WCF服务是提供特定功能的实体,通过接口(合同)与客户端进行交互。服务可以实现一种...

    分层架构体系研究1

    分层架构体系是一种常见的软件设计模式,用于组织和管理复杂系统的结构。3/N 层架构是一种多层架构模型,常用于构建...在实际项目中,理解并巧妙地应用这些架构模式,对于构建稳定、高效且易于维护的软件系统至关重要。

    基于Java与SpringBoot框架的分层架构设计源码实战教程

    该项目是一份基于Java与SpringBoot框架的分层架构设计源码实战教程,包含28个文件,涵盖11个XML配置文件、8个Java源文件、4个YAML配置文件、1个Git忽略文件、1个LICENSE文件、1个Markdown文件、1个Chat文件和1个SQL...

    高手系列!谈单片机程序设计中的“分层思想”

    尤其是在复杂的工程项目中,合理地运用分层设计可以有效地管理软件架构,提高开发效率和代码质量。对于单片机开发者来说,掌握分层思想是非常有益的,它不仅能帮助解决实际项目中的问题,还能提升个人的技术水平。

    基于项目的分层教学法在技校PLC课程教学中的应用.pdf

    总的来说,基于项目的分层教学法为技校的PLC课程教学提供了新的视角和实践路径,通过细分学生层次、设定分层教学目标、合理安排学习任务、科学实施项目教学以及客观公正地进行学生评价等环节,可以极大地提升技校...

    分层开发教程

    在本教程中,我们将关注如何进行分层开发,特别是针对SQL数据库和C#编程语言。 首先,分层开发通常包括以下四个主要层次: 1. **表现层(UI)**:这是用户与应用交互的界面,负责接收用户输入、显示输出和处理用户...

    基于.NET平台的分层架构实战

    本文概述了基于.NET平台的分层架构在NGuestBook项目中的应用。通过合理地规划需求、设计数据库、组织层次结构、实现实体类、定义接口以及运用依赖注入等技术,可以构建出高度模块化、易于维护和扩展的应用程序。这种...

    基于.NET平台的分层架构实战(完整资料).doc

    在实际项目中,需求分析和数据库设计至关重要。对于NGuestBook系统,需求包括:访客留言、管理员审核、评论功能、管理员权限管理等。数据库设计涉及管理员表、留言表、评论表等,需明确实体和关系,如管理员与留言...

    单片机程序设计里的“分层思想”

    在单片机程序设计领域,采用合理的架构和设计思想对于提升程序的可维护性、扩展性和效率至关重要。“分层思想”是一种非常有效的程序设计策略,它可以帮助开发者更好地组织代码,提高代码的复用率,并简化复杂系统的...

    .NET分层开发的几点心得

    本文将围绕.NET平台下采用分层架构进行应用开发的一些关键点进行探讨,尤其关注三层架构(表现层、业务逻辑层、数据访问层)在ASP.NET项目中的实践。 #### 一、数据实体层(Entity)的实现 数据实体层主要负责数据的...

    分层教学法在职业院校单片机教学中的应用.pdf

    应用分层教学法在单片机课程中,首先需要对学生进行分层,根据他们的学习现状以及对任务所需知识的掌握程度,将学生分为提高层、中间层和基础层。分层后,将学生合理搭配到小组中,并选择小组长。接着是任务分层,...

    C语言之嵌入式系统软件架构思想

    而在C语言中,模块化设计与分层思想是构建稳定、可维护软件架构的关键。 ### 模块划分的重要性 模块划分指的是将大型软件项目分解为若干个功能独立的模块,每个模块负责一部分特定的功能,通过接口与其他模块交互...

    asp.net BBS源码 分层实现

    在本源码中,开发者将业务逻辑、数据访问和用户界面进行了分离,以达到更好的软件工程实践。 1. **分层架构详解** - **表现层(Presentation Layer)**:这是用户与应用交互的界面层,通常包括ASP.NET Web页面、...

    C#经典分层收费系统源代码实例

    通过学习这个C#经典分层收费系统源代码实例,你不仅可以熟悉C#编程,还能了解MVC模式的工作原理,掌握如何使用分层架构来组织复杂的项目。此外,还能学习到如何处理数据库交互,以及如何实现业务逻辑。对于想要提升...

Global site tag (gtag.js) - Google Analytics