构建NetCore应用框架之实战篇(一):什么是框架,如何设计一个框架
一、系列简述
本篇起,将通过一系列文章,去描述如何构建一个应用开发框架,并以作者开发的框架为例,逐个点展开分析,如何从零开始,构建自己的开发框架。
本系列文章的目的,是带领有一编程经验的人,通过动手,初步完成自己的框架,更重要的是,获得构建框架的系统性思维模式。毕竟框架会过时,思维不会过时。
希望自己在技术有所深度,那么,主动、坚持、思考、行动,是四个最基本的要素。
二、作者简述
个人有十多年的软件工程工作经历,工作涉及软件工程的所有领域(需求策划、需求挖掘、需求分析、系统架构、功能设计,编码实现、系统测试、上线运维),对每个领域均有一定实践,不是每个领域最好的,但是应该是涉及领域最广泛的。
做过项目管理工作,实践过包括策划,沟通,计划,风险管理、过程监控等各专业管理域。
做过团队管理工作,实践过招聘,培训,考核,领导工作等企业组织域。
带领团队完成两次CMMI认证,对CMMI有一定认识,过程中积累学习了很多系统性思维,对软件企业整体运作有了更深刻理解。
优势是懂得各领域如何平衡,劣势当然是啥都不精通。
经过沉淀,最终对软件工程保持高度兴趣,热衷于知识输出和思想输出。
能够接受来自各方批评,但绝不改正。
三、什么是框架
言归正传,传递知识才是我们真正要做的事。
什么是框架,我们先来看一下百度百科的定义:框架(framework)是一个框子——指其约束性,也是一个架子——指其支撑性。是一个基本概念上的结构,用于去解决或者处理复杂的问题。
这个定义很清晰,框架包含两个含义,一个约束,二是支撑。更详细内容可以看百度百科,个人觉得解释很到位。去看看先
通过阅读,结合我们工作领域,我们知道我们定义的框架,叫软件开发框架。
比如:net core是一个框架,ef是一个框架,大家都叫框架,又好像有关联,有交叉,到底我们听谁的?
我们发现,软件开发框架,仍然是一个抽象的概念,当我们需要去落实一个具体的框架时,需要聚焦一个更细的问题。
net core是一个框架没错,它是定位在哪方面的框架,ef是一个框架没错,它是定位在哪方面的框架?
作者一直从事管理软件工作,所以,我定义的框架,就是指如何完成管理应用方面的框架。事实上,这种框架,几乎每个软件公司都有一个,每个程序员也梦想自己都能有一个自己的。
四、如何设计一个框架
我们已经知道框架的定义,那么,接下来就是行动起来。
管理系统开发过程,对程序员来说,属称增删改查。
站在设计的角度,我们对不同的需求进行抽象之后,发现管理系统需求包括表单、流程、报表。还有外部接口。
站在需求的角度,我们发现管理需求就是基础配置,业务流程,业务报表。当然,还有系统对接。
抽象到此,我们的框架要解决的问题已经足够清晰了,快速完成表单增删查改,快速完成流程驱动,快速完成报表。
接下来要做的是把框架的概念套进去:约束、支撑。
约束:我们需要用什么约定,去完成我们的开发,只有在这样的约定之下,我们才能达到快速开发的目的。
支撑:我们需要支撑哪些内容,完成这些支撑,我们对应用的快速开发便能呈现出有效性。
通过套用框架的概念,我们又可以产生新的问题:
我们的框架面向对象是谁?
他们平时都会遇到什么共通的问题?
我们的框架需要解决他们哪些问题?是否所有问题都需要解决?
我们的框架需要包含哪些模块?为什么需要包含这些模块?
我们提供什么样的开发模式,可以让开发人员更快速解决问题?
正确回答以上问题,那么,我们的框架长什么样子,实际上就已经有了整体架构了。
在实际操作过程中,不同人,不同经验,会提出不同的解决方法,每个人的方法,看起来都会很有道理,我们不讨论对错,我们认为只要能解决问题的方法就是对的。
个人比较擅长用系统性思维进行分析,也仅仅是代表解决问题的一种方式。
系统思维最基本就是分层,先定位好每个层次要解决的问题,再细分,哪些问题哪些方法,属于哪个层次,是否纳入,如何纳入。
事实上,对每一个细节的评判,都来源于我们日常的积累和认知,个人认为扩张自己的知识域,是能够客观评估问题的唯一方法。
本篇作为引入篇,也就写到这里,任何问题都可以无限展开,以问题作为切入,引起思考,个人认为已经足够了。
下篇将介绍BitAdminCore框架定位及架构,通过介绍进一步让大家了解我们如何思考的选择。
构建NetCore应用框架之实战篇(一):什么是框架,如何设计一个框架的更多相关文章
- 构建NetCore应用框架之实战篇(七):BitAdminCore框架登录功能源码解读
本篇承接上篇内容,如果你不小心点击进来,建议从第一篇开始完整阅读,文章内容继承性连贯性. 构建NetCore应用框架之实战篇系列 一.简介 1.登录功能完成后,框架的雏形已经形成,有必要进行复习. 2 ...
- 构建NetCore应用框架之实战篇(六):BitAdminCore框架架构小结
本篇承接上篇内容,如果你不小心点击进来,建议从第一篇开始完整阅读,文章内容继承性连贯性. 构建NetCore应用框架之实战篇系列 一.小结 1.前面已经完成框架的第一个功能,本篇做个小结. 2.直接上 ...
- 构建NetCore应用框架之实战篇(五):BitAdminCore框架1.0登录功能设计实现及源码
本篇承接上篇内容,如果你不小心点击进来,建议从第一篇开始完整阅读,文章内容继承性连贯性. 构建NetCore应用框架之实战篇系列 一.设计原则 1.继承前面框架架构思维,设计以可读性作为首要目标. 2 ...
- 构建NetCore应用框架之实战篇(四):BitAdminCore框架1.0登录功能细化及技术选型
本篇承接上篇内容,如果你不小心点击进来,建议从第一篇开始完整阅读,文章内容继承性连贯性. 构建NetCore应用框架之实战篇系列 一.BitAdminCore框架1.0版本 1.1.0版本是指最小版本 ...
- 构建NetCore应用框架之实战篇(三):BitAdminCore框架功能规划选择
本篇承接上篇内容,如果你不小心点击进来,建议从第一篇开始完整阅读,文章内容继承性连贯性. 构建NetCore应用框架之实战篇系列 一.BitAdminCore功能规划 如何选择框架的落地功能,前篇文章 ...
- 构建NetCore应用框架之实战篇(二):BitAdminCore框架定位及架构
本篇承接上篇内容,如果你不小心点击进来,建议重新从第一篇开始完整阅读. 构建NetCore应用框架之实战篇索引 一.BitAdminCore框架简介 从前篇论述我们知道,我们接下来将要去做一个管理系统 ...
- 构建NetCore应用框架之实战篇系列
构建NetCore应用框架之实战篇 构建NetCore应用框架之实战篇(一):什么是框架,如何设计一个框架 构建NetCore应用框架之实战篇(二):BitAdminCore框架定位及架构 构建Net ...
- 如何在Visual Studio 2017中使用C# 7+语法 构建NetCore应用框架之实战篇(二):BitAdminCore框架定位及架构 构建NetCore应用框架之实战篇系列 构建NetCore应用框架之实战篇(一):什么是框架,如何设计一个框架 NetCore入门篇:(十二)在IIS中部署Net Core程序
如何在Visual Studio 2017中使用C# 7+语法 前言 之前不知看过哪位前辈的博文有点印象C# 7控制台开始支持执行异步方法,然后闲来无事,搞着,搞着没搞出来,然后就写了这篇博文,不 ...
- Android网络框架Volley(实战篇)
之前讲了ym—— Android网络框架Volley(体验篇),大家应该了解了volley的使用,接下来我们要看看如何把volley使用到实战项目里面,我们先考虑下一些问题: 从上一篇来看 mQu ...
随机推荐
- 转)安装svn服务器
以下转载自:http://www.linuxidc.com/Linux/2015-01/111956.htm 安装 安装软件包: sudo apt-get install subversion 配置 ...
- TIME_WAIT状态的作用
TIME_WAIT状态: 主动关闭的那端最后经历的状态,一般为2MSL秒(1~4分钟). 两个原因: 保证当最后一个ack丢失后,能收到对端重传的fin包. 保证ack包消失,不会影响下一个连接. 关 ...
- Python调shell
os.system(cmd) 函数返回cmd的结束状态码,阻塞调用. os.popen(cmd) 函数返回cmd的标准输出,阻塞调用. (status, output) = commands.gets ...
- swift 设置图片动画组 iOS11之前 默认图片 设置不成功
在iOS 11 上, 1.先执行动画组 在设置图片执行帧动画,2.先设置图片在设置帧动画,执行帧动画 没有任何问题 在iOS 10和iOS9上,必须 执行 方法二(先设置图片在设置帧动画,执行帧动画 ...
- [leetcode]173. Binary Search Tree Iterator 二叉搜索树迭代器
Implement an iterator over a binary search tree (BST). Your iterator will be initialized with the ro ...
- [leetcode]403. Frog Jump青蛙过河
A frog is crossing a river. The river is divided into x units and at each unit there may or may not ...
- db2 sql调优
当我们发现某个SQL语句执行很慢时,可以通过查看它的访问计划来定位原因,如是否执行了合适的索引.是否采用了正确的连接方法等.但是我们发现很多用户对访问计划的生成和解释工具的使用存在很多疑惑,本文通过一 ...
- rsync 目录以 / 结尾 轻松同步数据
命令:#rsync –avz foo/ bar/ 意义:将 foo 目录之下的所有内容,同步到 bar 目录之下.如果不以斜杠结尾,意义就不同了.
- JMeter Ant Task 生成的*.jtl打开之后request和response data是空的,怎样让其不是空的呢?
JMeter Ant Task 生成的*.jtl打开之后request和response data是空的,怎样让其不是空的呢?修改JMeter.properties,将jmeter.save.save ...
- 深入浅出 JMS(四) - ActiveMQ 消息存储
深入浅出 JMS(四) - ActiveMQ 消息存储 一.消息的存储方式 ActiveMQ 支持 JMS 规范中的持久化消息与非持久化消息 持久化消息通常用于不管是否消费者在线,它们都会保证消息会被 ...