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

2023-10-23 13:04
文章标签 设计 开发 软件程序

本文主要是介绍如何从零设计开发一个软件程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

当参与了许多项目,或者见识了许多优秀的软件,难免心里会有一些波澜和冲动。谁又不想拥有一个自己的软件呢?
但是当自己独立开发一个软件时,发现挺难的,不知道该如何下手。
结合自己开发软件的心得进行描述,可能或多或少与你开发软件想法或见解存在碰撞,恕我愚见。

1. 明确需求

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

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

明确自己需求主要的功能特点。

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

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

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

在这里插入图片描述

2 .选择开发语言

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

选择适合自己的语言

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

我在构建桌面软件时,纠结选择electron(基于nodejs),还是swing/javafx,还是从零开始QT等等,当定下了开发的语言后,又在纠结我是开发一个插件(依赖于IDE),还是一个桌面软件。
重新评审了自己的需求,想在不同的操作系统上有一致的操作,从插件修改为桌面软件,是因为这样自己具备软件的可控性 。

3 .核心的业务逻辑

在这里插入图片描述

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

实现核心的业务逻辑是软件开发的目的。

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

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

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

4.软件的架构

常见的软件架构如下:

  1. 分层架构
  2. 多层架构
  3. 管道 - 过滤器架构
  4. 客户端 - 服务器架构
  5. 模型 - 视图 - 控制器架构
  6. 事件驱动架构
  7. 微服务架构

软件架构可能不是必须的,就像那个数据库生成文档程序(核心逻辑基于screw)一样,根本不需要什么架构,因为只是填写一些内容,点击生成按钮就结束了。
但是如果你需要开发的软件不是一个很简单,那么你需要一个合适的架构,当然架构并不是要贯穿所有层级,可以在UI层/逻辑层/核心层采用不同的软件架构。

那么什么样的架构更合适,是由你的需求所驱动的。

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

微内核架构示意图

在这里插入图片描述

5. 设计模式

常见的设计模式

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

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

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

    这么多设计模式该选择哪些?要不要选择设计模式,选择设计模式的好处是什么?

设计模式虽然不是必须的,但是它可以让代码看起来更优雅,可以根据需求选择合适的设计模式。比如:
无设计模式:小张家里只散养着土鸡,靠卖鸡为生。
工厂模式:有一天,小张开了一个养鸡场,对外提供各种类型的鸡。
代理模式:养鸡厂越做越大,小张收购了一个养牛场、养猪场、养鸭场等等,对外提供各种牲畜。
装饰器模式:小张的弟弟觉得饲养场利润太低,把各种肉产品进行礼盒包装,对外提供各种肉类礼盒。

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

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

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

在这里插入图片描述

最后

不同的人有不同的评价和偏好。在追求自己的兴趣和爱好时,尊重并理解他人的选择,所以,我并没有意图将自己的观点和喜好强加于人,毕竟每个人都是独一无二的,拥有自己独特的品味和价值观。
那么既然别人的经验和分享可能并不适合自己,不如花费些时间,学习并动手试一试,总结自己缺少的东西,可以不成功,但是不能不尝试,不要轻言放弃

这篇关于如何从零设计开发一个软件程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/268018

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧