对c#模块化开发理解

背景

        看了好多别人的项目,一直很不解,为什么一个c#项目要拆分成DAL一个项目,UI一个项目,service一个项目,然后相互引用,类似下图的这种结构。

        

        直接把ui,dal,service全部放到一个项目不也好了,用文件夹区分不就好了,为什么还要新建项目呢???,网上说是为了模块化、分层。

        我个人的理解是对于小项目,我个人是不喜欢分层的,直接写到一个项目里面就好了。但是对于一些大项目,分层的必要性就出来了。

        比如:一个项目中,有web端、有api、还有一个其他的。有人喜欢把web端跟api合并到一起放到一个项目中(当然这样也可以)。对于一些大的项目,最好把web端和api作为两个项目分开来。

        这时,web端和api肯定有重复操作的部分了。重复部分怎么办呢?不可能在web端写一份,api也写一份吧?(多麻烦)。所以这时候的模块化就出来了,把重复的部分抽出来,写到一个项目中(例如dal)。然后web端与api直接引用这个dal就好。

        其实这个跟Java的maven项目是差不多的,maven项目也是把dao、service、web层分为三个项目,然后dao、service最终打包成一个jar包给web使用。当然,dao和service也会互相引用。

        其实对于一些工具类,几乎好多的项目/小程序都会用到的,比如数据库的连接,这些东西可以直接抽出来作为一个项目的,然后给其他的项目直接引用即可。这样挺方便的。

        所以结论:尽管个人不是很情愿使用这种分模块的方式(感觉相比文件夹的方式稍微麻烦),但还是要养成这种开发模式。毕竟小项目最终也会变成大项目,到时候就要重构代码了,还不如直接一开始就分模块。

例子

        1、新建一个winform项目,命名为UI

        

         2、然后新建一个DAL的类库(右击解决方案-》新建项目-》选择下图的)

        

        3、最终生成结果如下图所示

        

        4、DAL中 随便写点

        

        5、然后在UI项目中引用(点击引用-》添加引用)

        

        6、找到DAL即可

        

        7、然后在UI中就可以直接使用了

        

        这样一个简单的引用小demo就实现了。当然在实际项目开发中,会有不止一个模块,反正原理就大概这样了。

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值