关于代码组织的一些看法(上)

今天看了一个篇关于架构的文章,略有所感,记录一下。

软件的架构基本是从一个原始需求出发,逐步构建可维护、更灵活的开发框架的过程,在这个构建过程中可能会逐渐的增加代码的复杂度来满足灵活性的要求,从这个层面来讲,复杂度和灵活性天生就是对立的,怎么平衡二者的关系,考虑到时间复杂度,成本等等因素,则演变成一门学问,就叫软件工程。以例子来说明呢会更加的清晰。

原始需求,基本办法

我们经常会解决一个问题,比如说我们为了方便给自己定了一个任务列表,在记录任务并可以查看任务状态,还可以更改和删除任务。解决这个需求不难想出一个数据表即可解决:

TaskList{

ID,--编号

Task,--任务名称

AwokeTime,--提醒时间

State --状态}

假定我是在WEB上操作,那么我想完成上述的几个需求,只需要如下几个方法

image

这是最基本的代码了,在一个webform的页面代码中即可以完成所有需求了,通过webconfig配置来改变数据库服务器的位置,通过一个简单的ExcuteSql方法来执行所有对数据库的操作。完成这个任务列表的功能,此时我们只需要一个aspx页面即可,可为什么还需要分那么多层呢。

"我想在Winform也能用"

做软件是为了给人解决问题的,人家就爱用winform的,怎么办,再来个winform的吧,好的,到这里一个软件有两个展现方式,如何解决呢,你在想重新将代码拷贝过来写一个类似web的form吗?那样的话会出现两个一模一样的insert方法,update方法等等,以后改动的话,如果用户有很多的界面展现方式,你要一个个都改吗?那么代码重用的问题出现了,将这些方法独立出来,一份代码web能用,winform也能用,如果想修改其中的某个方法,直接改就是了,代码的唯一性,真不错。

Win form  ----- web form

  \\                    //

insert,update,delete,search

代码怎么组织呢,我们可以再写一个类DB.CS,

image

里面有增删改查四个方法,但是数据操作方法是独立出来了,两种用户界面怎么办呢?大家都知道,winform和webform是需要建立两种项目的,那么我们只有将这个数据操作类在独立出来的基础上封装成程序集共两个项目共同引用了,于是,有了下面的转变

image ---》》image

这些简单的建立了一个比较容易修改数据操作部分和界面部分的模型。

“我们决定采用Oracle来存储数据”

软件嘛,需求的变更早已不再是新闻,客户可能已经有一个数据库,为什么要再投入那么大的成本去适应软件呢?试想一下,如果这个需求在前期并不明确,后期一旦改动我们开发人员将会多么被动,于是,我们可以做好预留,可问题是如果要改动数据操作方法,那么Architect.DB层的代码都要改动,难道我们要将全部代码重写一遍吗?不!我们是程序员,我们可以利用接口做另一套实现即可,如我们可以在某个地方轻松的将”SQL”改为”Oracle”即可让程序更换数据库多好啊,是的我们可以这样做,一个接口,两种实现,根据配置不同来选择不同的实现方式。

image

这样我们就可以根据配置的不同去动态的选择不同的实现,以后如果再有ACCESS的需求也不用怕,直接在加个实现就可以了,在类UserDBO中我们可以根据不同的条件来实例化两个不同的操作类。这样就实现了不同的数据库访问类,通常我们不会将这两种实现代码放到一个类中,分开管理更加方便,于是便有了下图

image

此时我们有了两种数据库的兼容方式,可以更加方便的更换数据库了,但是实际开发中的数据库访问类要复杂的多,所以很多时候我们会将数据访问接口和数据库的操作类分开,变成这样

image

这样做的好处是各个层面上的代码组织比较清晰,没有缠绕到一起,非常便于对各层的修改.然而代码组织到这里,是不是就完成了呢,刚开始看petshop的代码时,我也觉得分层有些太多了,但后来真的接触了比较多的开源代码后,发现是有道理的,下一篇随笔我将会继续写代码组织方面的一些个人见解,包括业务逻辑,缓存和面向服务等等,希望能跟大家交流。

转载于:https://www.cnblogs.com/wengyuli/archive/2010/06/23/code-organ.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/435535.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CE下基于Zylonite硬件平台的SD卡驱动开发

摘要:本文结合实际项目(一款以WINCE为操作系统内核的GSM/PHS双模智能手机)对嵌入式系统Windows CE5.0的底层驱动(SD卡)的架构进行了分析和研究,以MARVELL公司提供的基于INTEL Zylonite硬件平台的BSP为基础&…

【转】svn详解

转自:svn status详解 - 世界,太精彩 - 博客园 svn 是在提交前查看本地文本和版本库里面的文件的区别。返回值有许多种具体含义如下: L abc.c # svn已经在.svn目录锁定了abc.c M bar.c # bar.c的内…

outofmemory异常如何解决?

一年多来打交道最多的就是WinForm,界面设计确实比MFC容易多了,但是问题出的也更隐晦,要想完全解决还是离不开框架底层的知识。 现在又遇到了一个麻烦的问题:切换界面时,有时GroupBox(里面嵌有ListView&…

pthread-win32在VC2005下的使用

pthread-win32是一个在Win32环境下的Unix POSIX线程库的移植. 有了它, 可以比较方便的移植Unix/Linux多线程程序到Windows下. 在VC2005下使用也很简单: 下载, 地址是 http://sourceware.org/pthreads-win32 里面include目录中是头文件, lib目录中是.lib和.dll文件. 在VC项目的属…

【转】apt命令

转自:apt命令详解 - 简书 apt命令可以说是Ubuntu系统下最为重要的命令,安装、更新、卸载软件,升级系统内核都离不开apt命令。 一、apt的简介 apt的全称是Advanced Packaging Tool是Linux系统下的一款安装包管理工具。 最初的时候&#xff…

asp.net 之高速缓存

一、输出高速缓存 页面顶部插入&#xff1a; <% OutputCache Duration"60" VaryByParam"None" %> <% OutputCache Duration"60" VaryByParam"id;page" %> 二、部分页面高速缓存 (UserControl) <% OutputCache Durati…

【转】在 Bash 中使用 -exec 选项和 find 命令搜索文件

转自&#xff1a;https://www.delftstack.com/zh/howto/linux/linux-find-exec/ 我们可以使用带有 -exec 选项的 find 命令来查找包含我们要搜索的文本的文件。 主要概念是使用 find 命令获取工作目录中的每个文件&#xff0c;并执行 grep 命令查找每个文件中的文本。 例子&…

SQL Server 相关create操作语句

创建数据库&#xff1a; create database jylton (namejylt,filenamee:\db\jylt.mdf,size4,filegrowth100%,maxsize1024 )log on(namejylt_log,filenamee:\db\jylt_log.ldf,size4,filegrowth100%)go 1&#xff0c;增&#xff1a;insert into t_user values(wangpeng,19);s 2&a…

【转】svn st 状态详解

转自&#xff1a;svn st 状态详解 - 小小平凡世界 - 博客园 svn st status (stat, st): 显示工作副本中目录与文件的状态。 用法: status [PATH...] 未指定参数时&#xff0c;只显示本地修改的条目(没有网络访问)。 使用 -q 时&#xff0c;只显示本地修改条目的摘要信息。…

linux C之access函数

access()&#xff1a;判断是否具有存取文件的权限 相关函数 stat&#xff0c;open&#xff0c;chmod&#xff0c;chown&#xff0c;setuid&#xff0c;setgid 表头文件 #include<unistd.h> 定义函数 int access(const char * pathname, int mode); 函数说明…

gridview 强制过长数据进行换行

有时候设置gridview的列宽后&#xff0c;因为该列的内容为连续的数字或字母&#xff0c;不会自动换行。导致列宽不可控&#xff0c;可以通过以下方法设置列宽强制换行在绑定数据前添加一行 gv.Attributes.Add("style", "word-break:break-all;word-wrap:brea…

【转】string,wstring,cout,wcout 与中文字符的输入输出

转自&#xff1a;string,wstring,cout,wcout 与中文字符的输入输出 首先说明是什么string与wstring 在C标准里定义了两个字符串string和wstring typedef basic_string<char> string; typedef basic_string<wchar_t> wstring; 前者string是常用类型&#xff…

autoconf常用宏

AC_INIT (unique-file-in-source-dir)处理所有命令行参数并且寻找源代码目录。unique-file-in-source-dir是一些在包的源代码目录中文件&#xff1b; configure在目录中检查这些文件是否存在以确定该目录是否包含源代码。人们可能偶尔会用--srcdir给出错误的目录&#xff1b;这…

maple 2018 窗口关闭提示乱码_如果解决SOLIDWORKS工程图转CAD字体出现乱码的问题_SolidWorks生信科技...

操作SOLIDWORKS工程图转CAD时&#xff0c;由于SOLIDWORKS使用的是Windows字体&#xff0c;而CAD使用的是线性字体&#xff0c;字体就容易出现乱码的苦恼。一般出现乱码是因为字体映射里面没有中文&#xff0c;所以会导致乱码。遇到这种情况&#xff0c;只需找到字体映射文件&am…

解决firefox不能安装Flash插件

当你在浏览一个含有Flash的网页的时候&#xff0c;Firefox会提醒你正常浏览网页需要安装缺少的插件&#xff08;这个提醒通常在地址栏下方和Flash的占位区上&#xff09;&#xff0c;按照他的提示安装Flash插件即可。 另外你也可以手动安装&#xff0c;在Windows下, 可以在这里…

【转】apt 和 apt-get的区别

转自&#xff1a;https://www.sysgeek.cn/apt-vs-apt-get/ Ubuntu 16.04 发布时&#xff0c;一个引人注目的新特性便是 apt 命令的引入。其实早在 2014 年&#xff0c;apt 命令就已经发布了第一个稳定版&#xff0c;只是直到 2016 年的 Ubuntu 16.04 系统发布时才开始引人关注…

准确检测图像的轮廓 opencv_图像处理案例实战

1. 切边源图像&#xff1a; 需求&#xff1a;扫描仪扫描到的法律文件&#xff0c;需要切边&#xff0c;去掉边缘空白&#xff0c;这样看上去才真实&#xff0c;人工操作成本与时间花费高&#xff0c;希望程序自动实现&#xff0c;高效、准确。 实现思路&#xff1a;边缘检测 轮…

O_EXCL

open系统调用&#xff1a; #include <fcntl.h>int open(const char *pathname, int oflag, ... /*mode_t mode */ );其中&#xff0c;oflag有个可选值为&#xff1a; O_EXCL Generate an error if O_CREAT is also specified and the file already exists. This test fo…

sql 解锁被锁定的账号

账号被锁定&#xff0c;在属性那里直接取消lock-out无法解锁。运行这条命令即可&#xff1a;ALTER LOGIN UserLogin WITH PASSWORD NewPassword UNLOCK MUST_CHANGE 转载于:https://www.cnblogs.com/bigshot-z/archive/2010/07/12/1775856.html

ubuntu18分辨率变低,无法调整,最高只有1024*768

方法一 运行xrandr&#xff0c;判断哪个显示器分辨率最大&#xff0c;那个就是真实的显示器 记住是LVDS1还是VGA1这里记住显示的名称 如果是两个&#xff0c;那么恭喜你可以继续设置后 应该就好&#xff0c;只有一个请使用方法二 具体步骤&#xff1a; 下载arandr sudo apt-g…