全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:4009-999-999

如何从零设计开发一个软件程序

  当确定了构建软件需求时,开始前不要考虑太多功能,在没有详细考虑之前,这些功能内部可能存在相互驳斥,因为当背负的重担太多时,可能失去动力。

  如果对市场上的软件进行观察,通常这些软件具备一个明显的特征主题, 比如微信=聊天,网易云音乐=听音乐,网易有道词典=翻译等等。就像微信一开始并没有发送语音、视频聊天、朋友圈、微信支付等功能,即使有了这样功能,大家对微信标签还是聊天软件。

如何从零设计开发一个软件程序

  在想要热血心潮做一个属于自己软件时,发现夭折了好多次,觉得是因为技术不够扎实。读了好多书籍,比如《java编程思想》、《架构整洁之道》、《java2图形设计卷Ⅱ:SWING》、《Head First 设计模式》 等等,虽然读完后感受颇深,但是还是无从下手的感觉。

  知识储备固然重要,但是发现因为定义软件开发的原始需求,造成没有方向的盲目性,所以在开发软件前,要明确自己的需求,不论是要构建一个大厦还是一个土坯房。

  我的第一个软件只是简单的一个数据库转文档工具, 就如下图一样, 填写数据库信息并生成文档。

  有的人喜欢PHP 、JSP构建web软件,有的人喜欢VB、WPF、QT构建桌面软件,有的人喜欢react-native、java开发安卓软件等等, 而各种语言都有优秀的案例,比如WordPress 优秀的博客平台搭建软件是PHP开发的,Eclipse优秀的IDE开发软件是JAVA开发的,VLC优秀的视频播放软件基于QT开发的。

  在网上任何语言的缺点都可能被放大,可能在调研中就被帖子和论坛中别人的观点而劝退,所以选择一个自己喜欢的、适合自己的就足够了。

  我在构建桌面软件时,纠结选择electron(基于nodejs),还是swing/javafx,还是从零开始QT等等,当定下了开发的语言后,又在纠结我是开发一个插件(依赖于IDE),还是一个桌面软件。

  重新评审了自己的需求,想在不同的操作系统上有一致的操作,从插件修改为桌面软件,是因为这样自己具备软件的可控性 。

  从核心的业务逻辑出发,先去实现核心的业务逻辑,再去考虑框架、页面、数据库等等。核心的业务逻辑是开发软件的初衷,偏离了初衷就像丢了软件的灵魂一样。

  在未实现核心的业务逻辑前,不用考虑应用级的业务逻辑,因为如果核心逻辑不能用,再多的业务逻辑都是花里胡哨的表现,就像上述所说的数据库转文档软件一样, 把页面渲染的像花一样灿烂,但是最后不能生成文档,那么这个软件还没有出生,便已经夭折了。

  桌面软件、手机软件、浏览器软件、嵌入式软件、SDK等等,软件的类型没有高大上之分,适合自己需求的就是自己设计软件的目的。

  如果软件只能在IDE中或者只能在命令行中运行,但是它可以完成核心业务逻辑,只是它不能受众于其他用户而已。

  软件架构可能不是必须的,就像那个数据库生成文档程序(核心逻辑基于screw)一样,根本不需要什么架构,因为只是填写一些内容,点击生成按钮就结束了。

  但是如果你需要开发的软件不是一个很简单,那么你需要一个合适的架构,当然架构并不是要贯穿所有层级,可以在UI层/逻辑层/核心层采用不同的软件架构。

  我后来想整理很多工具,而数据库生成文档只是其中一个,所以我采用了微内核架构 ,为了复用一些UI组件、样式等。页面的构成也比较简单,左侧工具列表,右侧则为功能页面。

  1. 创建型模式:单例模式、抽象工厂模式、工厂方法模式、建造者模式、原型模式。

  2. 结构型模式:适配器模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、代理模式。

  3. 行为型模式:策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、状态模式、访问者模式、中介者模式、备忘录模式、解释器模式。

  设计模式虽然不是必须的,但是它可以让代码看起来更优雅,可以根据需求选择合适的设计模式。比如:

  代理模式:养鸡厂越做越大,小张收购了一个养牛场、养猪场、养鸭场等等,对外提供各种牲畜。

  装饰器模式:小张的弟弟觉得饲养场利润太低,把各种肉产品进行礼盒包装,对外提供各种肉类礼盒。

  当然理论说起来很轻松,开始的设计模式可能最优的,随着需求的迭代和升级,它可能随时发生变化程序开发,或者当具备丰富经验时,在开始实现前,评估适合自己的设计模式,结合自己在软件设计种的实际的例子来分享一下。

  本来原始需求只有一个转换器,但是我想扩展为多个转换器,发现因为转换器的改变,我需要频繁改变编辑区和状态区。所以选择了订阅者模式。

  使用订阅者模式的改造后的结构如图 ,左侧为文本编辑器,右侧为各种转换器,但是它们之间的通信方式,不再是直接引用调用方法,而改造为发布消息通知,接收消息后触发改变。

  不同的人有不同的评价和偏好。在追求自己的兴趣和爱好时,尊重并理解他人的选择,所以,我并没有意图将自己的观点和喜好强加于人,毕竟每个人都是独一无二的,拥有自己独特的品味和价值观。

  那么既然别人的经验和分享可能并不适合自己,不如花费些时间,学习并动手试一试,总结自己缺少的东西,可以不成功,但是不能不尝试,不要轻言放弃。

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。