首页 > 编程语言 >资深程序员必备技能-如何对软件系统做技术规划

资深程序员必备技能-如何对软件系统做技术规划

时间:2024-06-23 22:36:06浏览次数:22  
标签:方案 软件系统 必备 系统 技术 程序员 2.3 规划

1. 前言

本文是笔者对于技术规划的一些思考沉淀。如果这篇文章能帮助你入门技术规划,那自然是最好的,同时,正所谓教是最好的学,这也侧面了证明笔者已经掌握了技术规划的能力哈哈。

2. 我对软件系统技术规划的理解

软件系统技术规划,顾名思义,就是对软件系统做一些技术侧的规划,分三块描述:

  1. 软件系统
  2. 技术侧
  3. 规划

2.1. 软件系统

往大了说桌面端的PC软件,Web端的网页、移动端的APP等等都是软件系统,往小了说,一个服务,一个模块,一个组件,一个小工具也属于软件系统的范畴。任何一个软件系统都是可以做技术规划的,一方面世界上不存在完美的系统,总会有这样或那样的问题,把这些问题归因分类下,我们就可以做规划了;另一方面,世间万事万物总是向前发展的,即使现在的系统真的很完美,我们仍然可以思考系统未来的发展方向,并针对这个方向做一些技术探索甚至创新颠覆,这也是规划的一种。

2.2. 技术侧

技术侧是相对于业务侧来说的,本文虽然专注于技术视角,但是我们也要知道,技术和业务是相辅相成的,不能孤立的看待两者,有了业务的发展才有技术的用武之地,有了技术的支撑业务才能更好得发展,因此做技术规划的过程是绕不开业务话题的。

2.3. 规划

根据规划-百度百科的定义,

规划,是个人或组织制定的比较全面长远的发展计划,是对未来整体性、长期性、基本性问题的思考和考量,设计未来整套行动的方案

按我个人理解,主要有两个关键点:

  1. 规划即方案
  2. 规划即计划

2.3.1. 规划即方案

方案,是用来解决问题的措施,因此方案既要明确问题是什么,同时要避免假大空,要避免空中楼阁,要细化到怎么解决问题,或者说细化到解决问题的具体步骤。

规划即方案,说的是规划也要满足上述针对方案的论断,这点毋庸置疑。同时,规划相对于方案来说,首先侧重于解决基本性问题而不是一个两个BUG,其次正所谓不谋万世者,不足谋一时,不谋全局者,不足谋一域,好的规划需要从局部视角切换到全局视角,需要以一种较为全面整体的视角来出方案。

2.3.2. 规划即计划

2.3.2.1. 规划是面向未来的

规划主要是面向未来的,但是要想展望未来必先立足当下。对于一个软件系统而言,需要对系统的现状甚至过去的演进有一个足够的了解后,才能做出比较好的规划。

2.3.2.2. 规划是长期性的

规划需要面向多久的未来呢?一般情况下是3-12个月,时间太短了赶着落地可能会出一大堆Bug,而且谁也不想天天活在Dealine的恐惧中;太长了也不好,正所谓计划赶不上变化,万一出现了一些意外情况导致结果不及预期,那么船小还能掉头。

2.3.2.3. 规划是要排期落地的

规划需要落地执行,简单来讲就是排期,在某个时间节点完成某项功能。

2.4. 小结

  1. 无论大小系统都可以做技术规划
  2. 做技术规划不能脱离业务视角
  3. 规划既是计划,也是方案。从这两点出发,那么其实也就引出了规划的方法论:
    1. 梳理过去/现状
    2. 展望未来,提出理想态
    3. 基于过去/现状和理想态的差距,自然就可以发现基本性问题
    4. 针对问题设计解决方案
    5. 排期时间,落地执行解决问题

3. 为什么要做规划

事事都离不开规划,大到国家,有五年规划,小到个人,有人生规划和职业规划等。做规划在我理解最大的好处是,有了目标和方向感,有了目标和方向感就不会迷茫并且能正确发力,精力只有用到正确的地方才能起到事半功倍的作用。

具体到软件系统技术规划也是一样的道理,有了规划我们才能稳扎稳打的做出对用户更友好的系统,甚至成为业界标杆;当然,还有一个更现实的原因,对于一个程序员而言,如果不掌握规划能力的话,那么是无法进一步往上发展的,它是我们迈向资深程序员的必备技能。

4. 如何对软件系统做技术规划

4.1. 收集资料

收集资料贯穿整个技术规划的始终,只有足够的输入才能有输出,资料包括但不限于代码、以前的规划文档、技术方案、接入文档等等

4.2. 梳理现状

从两个方案入手梳理现状:

  1. 业务功能
  2. 技术架构

4.2.1. 业务功能

我们可以实际从头开始体验系统,了解系统有哪些角色,代入这些角色实际操作一把系统,并最终沉淀一份接入文档。

4.2.2. 技术架构

体验系统的过程中我们可以抓包、查日志、看代码等方式梳理系统的架构和链路,最起码总结出以下两张图:

  1. 分层架构图
  2. 核心链路图

4.3. 展望未来提出理想态

有两种方法可以推测系统的未来:

  1. 归纳法
  2. 演绎法

4.3.1. 归纳法

我们可以去做竞品调研,了解司内司外同类系统是怎么做的,并整理归纳下,对比我们的系统就知道未来需要做什么了。

4.3.2. 演绎法

但是如果竞品系统没有值得借鉴的地方怎么办呢?那我们可以从本质出发,思考系统的本质是什么,为谁服务,基于此进行逻辑推理与演化思考,从而推导出系统的未来理想态,就如同本文最开始从规划是什么的定义出发,带出了怎么做规划的方法论。

4.4. 发现问题

什么是问题呢?现实和理想的差距就是问题。前文梳理现状和预测未来提出理想态如果已经搞清楚了,那么发现问题自然不在话下,具体而言,可以从以下几个方面总结问题

  1. 技术架构层面
  2. 接入效率层面
  3. 性能层面
  4. 稳定性层面
  5. 成本层面
  6. ...

4.5. 设计解决方案

针对一个问题,我们需要提出至少3个解决方案,并总结每个方案的优缺点,再进行对比选型,最后,针对选型出的方案总结出两张图:

  1. 分层架构图
  2. 核心链路图

4.6. 排期落地

方案出来了,剩下的就是排期落地,其实就是列出Todo项,根据优先级排序,并一项项得完成之。

标签:方案,软件系统,必备,系统,技术,程序员,2.3,规划
From: https://www.cnblogs.com/ThinkerQAQ/p/18264016

相关文章

  • 软件项目过程必备文档整理大全(内容丰富,直接套用)
    在软件开发过程中,文档扮演着至关重要的角色。它不仅记录了项目的需求、设计和开发过程,还为项目的维护和管理提供了便利。本文将详细介绍软件开发文档的重要性和作用,以及需求分析、软件设计、开发过程、运维管理和项目管理等方面的文档编写要点。获取:点我获取引言软件开发文......
  • LLM技术全景图:技术人必备的技术指南,一张图带你掌握从基础设施到AI应用的全面梳理
    LLM技术全景图:技术人必备的技术指南,一张图带你掌握从基础设施到AI应用的全面梳理LLM技术图谱(LLMTechMap)是将LLM相关技术进行系统化和图形化的呈现,此图谱主要特点是“专注于技术人视角”,不求从LLM产业角度汇聚信息,而是希望让从事相关工作或是想了解LLM的技术人有一个快速......
  • 女程序员如何发展???
    女程序员在技术行业中相比于男程序员可能会面临一些更多的问题或是质疑。有很多的方面,比如性别歧视,职场文化,工作和生活平衡,性骚扰等等还有许多问题,那么女程序员如何打破这些问题去寻找自己的发展之路。    1.保持自信,保持热情,客服偏见。相信自己的能力,不要因为性别而......
  • 一、若依--P2--P5【黑马程序员Java最新AI+若依框架项目开发新方案视频教程,基于RuoYi-V
    学习视频【黑马程序员Java最新AI+若依框架项目开发新方案视频教程,基于RuoYi-Vue3前后端分离版本,从前端到后端再到AI智能化应用全通关】https://www.bilibili.com/video/BV1pf421B71v/?p=6&share_source=copy_web&vd_source=3949d51b57b2891ea14d6e51c792bef6P2:前端框架搭......
  • 300部幼儿园儿歌舞蹈视频大合集,家有萌娃必备
    亲爱的家长朋友们,您是否正在寻找适合您孩子的有趣活动,既能激发他们的艺术天赋,又能让他们在快乐中成长?我们为您精心准备了一个包含300部作品的幼儿园儿歌舞蹈视频大合集,让您的萌娃在家也能享受幼儿园的乐趣!《你好你好》教会孩子们见面时的礼貌用语,通过活泼的舞蹈动作,让孩子们学......
  • 大学生必备!GitHub星标破千的matlab教程(从新手到骨灰级玩家)
    MATLAB(MatrixLaboratory)是MathWorks公司推出的用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境的商业数学软件。MATLAB具有数值分析、数值和符号计算、工程与科学绘图、数字图像处理、财务与金融工程等功能,为众多科学领域提供了全面的解决方......
  • 【B站黑马程序员LINUX 学习笔记 01】
    课程看的是b站黑马程序员的https://www.bilibili.com/video/BV1n84y1i7td/?spm_id_from=333.337.search-card.all.click&vd_source=be621a30ea2e4e0374f5df95b0b017f201操作系统概述计算机由:硬件和软件组成。操作系统是计算机软件的一种,它主要负责:作为用户和计算机硬件......
  • 【热门开源项目推荐】满足不同程序员的需求与关注点
    目录前言一、热门开源项目介绍二、使用开源热门项目的优势(一)经济方面(二)技术方面(三)社区支持及协作方面三、程序员选择项目模型建议(一)关键步骤(二)示例选择流程小结前言随着开源程序的发展,越来越多的程序员开始关注并加入开源大模型的行列,对于开源行业和开源项目不同......
  • 从12个视角看全球C++程序员2/5:深度解读JetBrains最新报告
    讲动人的故事,写懂人的代码4C++程序员最常使用哪种IDE?总体情况(General)VisualStudioCode(VSCode):27%CLion:26%VisualStudio:26%Vi/Vim:4%QtCreator:3%其他工具的使用率较低,分别占据1-2%。嵌入式开发(Embedded)VisualStudioCode:34%CLion:29%VisualStudio:19%......
  • 今天在地铁认识一个女程序员,在外包公司工作三年,只赔偿4000
    “下一站,xx软件园……”地铁广播响起,车厢里再次骚动起来。提着电脑包的、抱着文件袋的,一个个行色匆匆,奔赴各自的“战场”。在这熙熙攘攘的人群中,我注意到了一位特别的女生。她看起来很年轻,却难掩眉宇间的疲惫和迷茫。我们偶然间聊了起来,得知她叫小雨(化名),985硕士毕业,今年刚......