【唠唠嵌入式】__嵌入式开发需要从0开始造轮子吗?

news2024/10/6 17:32:30

目录

前言

从0开始和套用模板的利弊

1. 从0开始的利弊

2. 套用模板的利弊

从0开始,还是套用模板?

1. 看项目赶不赶

2. 看项目用途

3. 看工程师水平

4. 看领导决策

5. 看公司决策

6. 看项目规划

实际工作

总结

(* ̄︶ ̄)创作不易!期待你们的 点赞、收藏和评论喔。 


前言

看到有小伙伴在讨论关于“造轮子”的话题,各有各的观点,这里先说两种常见的情况。

  • 第一种情况

老板从来不催进度,做项目的工程师也不慌不忙,从零开始一步一步创建工程,然后一步一步写代码(即从0开始造轮子)。

当把项目做好,或者项目才做到一半时,公司可能就已经倒闭了。

  • 第二种情况

老板要求在尽量短的时间把项目赶出来,好,直接套用各种模板(比如:单元模块、软件库、协议栈等),东拼西凑,终于,在规定时间完成了项目,项目也勉强运行起来。

某一天,老板让新加一个功能,发现与原来的功能有冲突,那该怎么办?重新开始写代码?

你会发现:不管是从0开始造轮子,还是直接套用模板都存在弊端。

从0开始和套用模板的利弊

从0开始,意味着整个项目都由工程师一步一步完成,而不用各种现成的模板。

凡事没有十全十美,从0开始和套用模板都有优点,也都有缺点。

1. 从0开始的利弊

  • 好处:软件的各种逻辑自己比较清楚,方便后期增、删、改、查。
  • 缺点:比较费时间,而且,软件存在bug的可能性比较大。

2. 套用模板的利弊

  • 好处:软件可靠稳定(当然,指的是市面上常见的软件库、协议栈等),也节约开发时间。
  • 缺点:可能与你项目存在冲突,比如存在阻塞情况,比如占用资源比较等。

从0开始,还是套用模板?

这里我也不能说哪一种好,哪一种不好,最终还是要结合你项目实际情况。

1. 看项目赶不赶

如果项目开发时间相对宽松(不那么赶项目),可以从0开始搞起。比如:前期尽量抽时间规划好项目,搭建好软件框架等。

如果项目要在最短时间内赶出来,可以套用一些现成模板,甚至直接从GitHub下载一个类似项目简单修改,以完成功能为主,先上(zheng)线(qian),然后慢慢优化。

2. 看项目用途

如果写一个软件,只是单纯的拿给客户演示,能用模板就用模板吧。

如果定位是一个大批量生产的产品,建议从0开始,结合成熟模板做起来。

3. 看工程师水平

如果工程师是一个菜鸟,你让他从0开始,等项目做好估计黄花菜都凉了。还有,即便项目做好了,可能Bug也无数。此时,还是建议你参考别人的模板,或者源码(当然,不是网上随便找的那种哈)。

如果工程师是有一定经验,手上项目没有很多的参考模板,可以从0开始做起。

4. 看领导决策

······

5. 看公司决策

······

6. 看项目规划

······

实际工作

公司项目立项的时候,各种近期、远期规划都有,就连嵌入式软件各种细节也是做了各种规划。比如:模块(模块化)、软件命名、软件框架等。

总之,前期花了很多时间做了很多准备工作,然后,项目按照规划一步一步从0开始搞起来。

前几年项目也非常顺利,虽然偶尔有小bug,但很快就能锁定bug并快速得到解决。

但是,随着市场的变化,功能改变和增加的情况越来越多,时间也越来越紧张,在增加、修改、删除功能或模块的时候,没有太多时间优化项目。

终于,项目暴露的问题越来越多,测试部反馈的一级bug也越来越多,市场也经常反馈问题。

最终,实在没办法,项目暂停,重新整理软件架构,在一个月之后,更新架构的软件完成了,也比较顺利。

说明一下:

整个软件项目做到后面比较大,其中也套用了第三方库、协议栈等。因为项目做的很多规划(准备工作),前期开发的也比较顺利,但后面项目紧张没有优化,代码叠加就更容易引起bug。

好在前期做足了工作,比如模块化、代码高内聚低耦合等,在后面软件重构也相对比较顺利,很多模块都可以直接复用。

总结

从0开始还是套用模板,应该遵循几个原则:

  • 项目开发时间越短越好

  • 项目越稳定越好

  • 项目后期增删改查越容易越好

  • ······

在不能平衡的情况下,就要有所取舍,但要尽量平衡。就像上面说的,赶进度而未优化,为后期留下后患。

因此,一般建议先规划项目,像软件框架、结构这种结合项目情况从0规划,然后参考或者套用一些成熟模板,再次,在编码过程中,不断优化和完善代码。

最终不管什么方式,目的是使项目稳定,方便增删改查。


(* ̄︶ ̄)创作不易!期待你们的 点赞收藏评论喔。 

本文来源网络,免费分享知识,版权归原作者所有。如涉及作品版权问题,请联系我进行删除!

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

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

相关文章

react-native 0.63 适配 Xcode 15 iOS 17.0+

iOS 17.0 Simulator(21A328)下载失败 App Store 更新到 Xcode15 后,无法运行模拟器和真机。需要下载iOS 17对应的模拟器。Xcode中更新非常容易中断失败,可以在官网单独下载iOS 17模拟器文件,例如:iOS_17.0.1_Simulator_Runtime.d…

​软考-高级-信息系统项目管理师教程 第四版【第24章-法律法规与标准规范-思维导图】​

软考-高级-信息系统项目管理师教程 第四版【第24章-法律法规与标准规范-思维导图】 课本里章节里所有蓝色字体的思维导图

线性代数 | 矩阵运算 加减 数乘 矩阵的幂运算

文章目录 1. 矩阵加减和数乘2.矩阵与矩阵的乘法2.1相乘条件:看中间,取两头2.2 相乘计算方法 3. 矩阵的幂3.1 观察归纳法3.2 邻项相消法3.3 化为对角 4.矩阵求逆(除法)4.1 判断是否可逆(证明题或者要求求出逆矩阵&#…

React事件绑定的方式有哪些?区别?

一、是什么 在react应用中,事件名都是用小驼峰格式进行书写,例如onclick要改写成onClick 最简单的事件绑定如下: class ShowAlert extends React.Component { showAlert() { console.log("Hi"); } render() { ret…

conda环境中pytorch1.2.0版本安装包安装一直失败解决办法!!!

conda环境中pytorch1.2.0版本安装包安装一直失败解决办法 cuda10.0以及cudnn7.4现在以及安装完成,就差torch的安装了,现在torch我要装的是1.2.0版本的,安装包以及下载好了,安装包都是在这个网站里下载的(点此进入&…

《研发效能(DevOps)工程师》课程简介(五)丨IDCF

由国家工业和信息化部教育与考试中心颁发的职业技术证书,也是国内首个研发效能(DevOps)职业技术认证,内涵1000页学习教材2000分钟的课程内容讲解460多个技术知识点300多道练习题。 在这里,你不仅可以了解到华为、微软、…

Go-服务注册和发现,负载均衡,配置中心

文章目录 什么是服务注册和发现技术选型 Consul 的安装和配置1. 安装2. 访问3. 访问dns Consul 的api接口go操作consulgrpc下的健康检查grpc的健康检查规范动态获取可用端口号 负载均衡策略1. 什么是负载均衡2. 负载均衡策略1. 集中式load balance2. 进程内load balance3. 独立…

Python+Selenium+Unittest 之selenium12--WebDriver操作方法2-鼠标操作1(ActionChains类简介)

在我们平时的使用过程中,会使用鼠标去进行很多操作,比如鼠标左键点击、双击、鼠标右键点击,鼠标指针悬浮、拖拽等操作。在selenium中,我们也可以去实现常用的这些鼠标操作,这时候就需要用到selenium中的ActionChains类…

采用springboot 2.7.10来操作clickhouse

1、采用springboot与clickhouse结合&#xff0c;其实和操作mysql&#xff0c;oracle区别不大。直接上代码开干 2、所采用的环境 jdk1.8 springboot 2.7.10 clickhouse 22.8.3.13 clickhouse 0.5.0 3、项目的pom.xml文件 <dependency><groupId>com.clickhous…

基于SSM框架的共享单车管理系统小程序系统的设计和实现

基于SSM框架的共享单车管理系统小程序系统的设计和实现 源码传送入口前言主要技术系统设计功能截图Lun文目录订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码传送入口 前言 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;…

整理笔记——稳压直流电路知识

一、稳压直流电路的基本构成 稳压直流电路就是把生活中常用的220V交流电转换成稳压直流电。如生活中常见的手机充电器就是一个稳压直流电路。其主要功能是提供持续稳定且满足要求的电压。 直流稳压电路由一下几个模块组成&#xff1a; 下面具体分析下各个模块的功能。…

编译原理——构造预测分析表(判断某字符串是否是文法G(E)的句子)

进入今天的学习前&#xff0c;若不理解LL(1)文法中的首符号集&#xff0c;后跟符号集和选择符号集&#xff0c;可看&#xff1a; http://t.csdnimg.cn/BjSHv 构造预测分析表的步骤&#xff1a; 步骤1&#xff1a;对文法的每个规则U->u,执行步骤2与3 步骤2&#xff1a;对…

Springboot---整合对象储存服务MinIO

OSS 「OSS」的英文全称是Object Storage Service&#xff0c;翻译成中文就是「对象存储服务」&#xff0c;官方一点解释就是对象存储是一种使用HTTP API存储和检索非结构化数据和元数据对象的工具。 白话文解释就是将系统所要用的文件上传到云硬盘上&#xff0c;该云硬盘提供了…

chatGPT使用情况

作为一个语言模型&#xff0c;我&#xff08;ChatGPT&#xff09;被用于各种不同的应用场景。以下是一些常见的情况&#xff1a; 个人助手&#xff1a;人们可以使用我来获取信息、解答问题、获取建议或进行闲聊。我可以提供各种知识和帮助&#xff0c;从学术知识到日常生活的建…

nginx发布vue项目

1、docker拉取nginx镜像 docker pull nginx:latest2、docker安装nginx # 第一个80端口是主机端口&#xff0c;第二个80端口是内部端口&#xff0c;主机的端口 80 映射到容器内部的端口80 docker run -d --name nginx -p 80:80 -p 443:443 nginx:lateste3、输入IP访问 说明我们…

javaEE进阶

Cookie 是可以伪造的,比如说学生证是可以伪造的 Session 是不可以伪造的,这是学校系统记录在册的 如何获取 Cookie 我们先用 Servlet 原生的获取 cookie 的方式 我们在浏览器进行访问 但是实际上目前是没有 cookie 的,我们按 F12 进行添加 然后再重新访问,就能在 idea 看到 …

什么是高敏感型人格,高敏型人格如何改变自己

什么是高敏感型人格&#xff1f; 高敏感型人格&#xff0c;指的是个体情绪敏感度高&#xff0c;有好处也有不好的地方&#xff0c;比如说好处吧&#xff0c;高敏感型人格他们对情绪的感知更加细腻&#xff0c;这种特征在创作和设计方面&#xff0c;往往能到达常人所不能达到的…

NIO讲解

一&#xff1a;什么是NIO? 二&#xff1a;NIO三大组件 1. channel channel 有一点类似于 stream&#xff0c;它就是读写数据的双向通道&#xff0c;可以从 channel 将数据读入 buffer&#xff0c;也可以将 buffer 的数据写入 channel&#xff0c;而之前的 stream 要么是输入…

C/C++轻量级并发TCP服务器框架Zinx-游戏服务器开发006:基于redis查找玩家姓名+游戏业务实现总结

文章目录 1 Redis的安装与API的使用1.1 安装目录及环境变量1.2 设置远程客户端连接和守护进程1.3 启动redis1.4 Hiredis API的使用1.5 我的动态库和头文件 2 Redis的使用2.1 初始化时候2.2 结束的时候 3 测试4 Makefile5 游戏业务总结 1 Redis的安装与API的使用 1.1 安装目录及…

Kotlin HashMap entries.filter过滤forEach

Kotlin HashMap entries.filter过滤forEach fun main(args: Array<String>) {val hashMap HashMap<String, Int>()hashMap["a"] 1hashMap["b"] 2hashMap["c"] 3println(hashMap)hashMap.entries.filter {println("filter $…