0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

嵌入式开发一定要学设计模式吗?

strongerHuang 来源:技术让梦想更伟大 作者:李肖遥 2021-04-02 10:50 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

刚开始工作的两年,我做项目写代码不会考虑代码扩展、移植、模块化等,导致项目有新增功能、或修改的时候不知如何下手。今天分享一篇肖遥整理的关于设计模式的文章,希望对大家有帮助。

工作有些年了,每每看到一些朋友会问,设计模式需要学吗?好像做嵌入式的从没遇到过需要用设计模式的,所以一直没系统学习,但是我也知道这个很重要,久而久之,到头来还是没学。 这里我说一下自己的看法和思考,来看看一些问题。

1

什么是设计模式?

设计模式是代表了开发人员不断积累的最佳的实践,是软件开发人员在软件开发过程中面临的一般问题的最优解决方案。

也就是说,经过了不断的发展,不同的问题或者方案有对应的一套法子,而这个法子被总结成了这么几十种通用模式,我们如果遇到了就对应着去套用就可以了。 当然那几大开发原则和二十几种设计模式大家还是随便去找都可以找到说明的,笔者就不多说了(我也只用到了其中几种),大家自行学习为好。

2

开发中为什么很少用设计模式?

在平时项目开发中,我们很少使用设计模式,我感觉这个现象还是很正常的,不是说工作中没用到设计模式,而是大多数情况下我们项目中没想那么多,更多的是做一些需求更改,而忽略本质。

设计模式的目的是提供可拓展性和可维护性,但是我们开发的项目本身,大部分都是固定写死的,逻辑单一,我们开发的模块也并不在其他的位置或项目中复用,目的很明确就是做当前的业务。 平时开发中用到设计模式的地方很少,但是框架就不同的了,框架必须适应不同的项目,具备高弹性和拓展性。他们要能适应各种不同的环境,所以,设计模式在框架设计中处处可见。 假如一开始在大公司或者接手一个接近成熟的项目时,那大概率会负责一些小模块或者细分领域的开发;而在小公司或者是几乎从零开始做项目的时候,可能我们本身还不够去设计一个符合项目长期规划的架构,最终导致写的代码比较乱,维护性差。 所以在嵌入式开发中,当我们有了一定的基础和项目经验的时候,我们就会想着,嗯,一个好的架构多么重要啊,或者我需要去好好学一下设计模式了。

3

嵌入式开发一定要学设计模式吗 ?

可以这么说,设计模式为拓展而生。

平时项目中的业务逻辑代码,大部分功能是死的,是专为这个场景而生的,不会在另外的场景中出现,这种业务的开发,是不需要设计模式的。 但是如果需求有变化,我们一般可能就直接修改源代码了,这样实际上带来了一定的修改成本,而为了一个项目中可能不明确的未来变化,而精心设计扩展性很高的架构,成本也是显而易见的,所以,这是一个取舍。 当然,从长期来看,一个好的设计是值得的,毕竟与其不断的修改新的需求,还不如一劳永逸,这样开发人员才能从各个方面高效去开发了。 在嵌入式软件开发中,当软件系统到达一定的复杂程度时,设计模式就显得尤为重要。虽然搞嵌入式的常常是基于一些16位/32位/64位单片机开发,而且这些可能受一些硬件方面的限制,但是单片机软件也是可以遵循软件工程的基本原则来进行架构的。 从代码组织的角度比如组件化、分层、去耦等等,或者从设计角度比如基于消息队列、事件驱动等等,都是有因可循的。 所以对于这个问题,嵌入式开发最好是要学设计模式,这里鼓励大家多看看重构、设计模式、面向对象的C等方面的书籍。

4

设计模式该怎么学?

前面说了那么多,设计模式是什么,嵌入式中哪里用到了设计模式,设计模式到底需不需要学等等,好,那你告诉我到底怎么学!

这里我想分一些情况来说,关于这个问题,设计模式怎么学习,得看你的程度、你主要解决什么问题、你负责的部分而定。 若你的编程水平或者学习的程度还没到那(还在学习怎么编程阶段),看了自然是懵逼的,这个时候还是好好补补基础知识,这些还用不到。 若在项目当中,你解决的大部分是一些业务逻辑,这种情况能用的设计模式不多,因为需要的是业务模式,也就是参考设计模式原理,自己设计业务模式改改需求啥的,就没必要了。 若你负责或参与应用框架或与其相关,那帮助就大了,这个时候用什么设计模式,怎么去设计就要考验功底了。 当然,不管怎么说,只要有时间即使是你目前程度还不到,你也可以学习设计模式使自己提升程度,但得一步一步来,稳中进步。 这个学习也不是一次性把所有的都学习了,这样其实也很难掌握,可能只是知其表而已,一般先从某个与你要处理的问题相关或者常会遇到的模式开始学起,一次学一个,学的深一些。 大部分人最常提的是单例、工厂、策略这几个,比如一个功能,要求既要支持串口通信,又要支持TCP通信,而对调用方来说最好不要知道它们的区别,这就是典型的策略模式场景。 这种比较常见的情况,很多项目中都可能遇到,因此不可能不学,网上也有很多经验分享,还有很多教程例子,这个时候也不可能学不会。

5

总结

到此,你觉得设计模式有没有用?

每个人的情况不同,学习过程不一定是这样,做的工作内容肯定也不一样,关键点是只要你在这行,在写代码,那么一般一定用得到其中几个模式,等你学会几个,并且常用,时间久了自然就明白了。

原文标题:嵌入式开发中为什么很少用设计模式?

文章出处:【微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5212

    文章

    20777

    浏览量

    338878

原文标题:嵌入式开发中为什么很少用设计模式?

文章出处:【微信号:strongerHuang,微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    低代码可视化,破解嵌入式开发高门槛难题

    。PPECWorkbench以低代码可视化为核心,打造一站式嵌入式开发解决方案,精准破解行业痛点,为嵌入式开发行业注入新活力。嵌入式开发
    的头像 发表于 03-25 14:13 285次阅读
    低代码可视化,破解<b class='flag-5'>嵌入式开发</b>高门槛难题

    嵌入式开发是否会成为下个被看好的领域?

    嵌入式开发会不会成为下个风口,现在确实是个挺热门的话题。各种论坛、投资报告都在讲物联网、智能硬件、AIoT的万亿市场,仿佛只要跟嵌入式沾边,就能乘着东风起飞。但如果套用我们刚才聊的那套逻辑,就会发现,这事儿还真“不好说”,得
    的头像 发表于 02-26 09:56 723次阅读
    <b class='flag-5'>嵌入式开发</b>是否会成为下<b class='flag-5'>一</b>个被看好的领域?

    嵌入式开发常用函数速查表

    嵌入式开发中,掌握常用函数的用法可以大大提高开发效率。无论是单片机初学者还是有一定经验的工程师,熟悉函数库和调用方式都是必备技能。今天,我们为大家整理
    的头像 发表于 01-19 09:06 539次阅读
    <b class='flag-5'>嵌入式开发</b>常用函数速查表

    什么是嵌入式应用开发

    概述 所谓的嵌入式应用开发就是在嵌入式操作系统下进行开发、软硬件综合开发嵌入式应用
    发表于 01-12 16:13

    从零搭建嵌入式开发环境:C、Makefile、调试全流程

    “配置”,但它是每个嵌入式工程师的入门仪式。你能否顺利跑通第个程序,决定了你之后能不能真正理解底层逻辑。今天我们就从最基础出发,完整走嵌入式开发环境的构建流程
    的头像 发表于 01-09 19:04 1010次阅读
    从零搭建<b class='flag-5'>嵌入式开发</b>环境:C、Makefile、调试全流程

    性能与性价比兼得!迅为RK3562开发板开启嵌入式开发新选择

    性能与性价比兼得!迅为RK3562开发板开启嵌入式开发新选择
    的头像 发表于 12-23 16:10 1943次阅读
    性能与性价比兼得!迅为RK3562<b class='flag-5'>开发</b>板开启<b class='flag-5'>嵌入式开发</b>新选择

    从编译器到体化平台:IAR重塑嵌入式开发模式,并赋能RISC-V高效创新

    点评这起收购时表示:“支持IAR向基于订阅的商业模式过渡”。这句话背后究竟蕴含着怎样的深意?IAR首席产品官Thomas Andersson在接受电子发烧友网等媒体采访时给出了详细解读。 开发模式变革:从单
    的头像 发表于 12-10 09:26 5075次阅读
    从编译器到<b class='flag-5'>一</b>体化平台:IAR重塑<b class='flag-5'>嵌入式开发</b><b class='flag-5'>模式</b>,并赋能RISC-V高效创新

    个面向单片机、事件驱动的嵌入式开发平台介绍

    EventOS,是个面向单片机、事件驱动的嵌入式开发平台。它主要有两大技术特色:是事件驱动,二是超轻量。EventOS以及其母项目EventOS,目标是开发
    发表于 12-05 06:26

    分享嵌入式开发学习路线

    拓展期(3-4个月) 学习嵌入式操作系统(RTOS)和物联网通信技术,能开发“多任务、联网”的复杂项目,理解企业级嵌入式开发的“架构思维”。这阶段的学习需要
    发表于 12-04 11:01

    嵌入式开发工具版本的选择策略

    今天,我们就来结合嵌入式常见的几个软件(如Keil / IAR、VS Code 、Source Insight、VMware、Git等),简单讲嵌入式开发工具软件版本选择策略。 开发
    发表于 11-25 06:11

    嵌入式开发的关键点介绍

    嵌入式系统的应用非常广泛,例如:智能家居、智能手表、智能手机、智能汽车等等。嵌入式开发需要开发人员具备深入的硬件知识和编程经验,但是也有嵌入
    发表于 11-13 08:12

    GT2440嵌入式开发系统用户手册

    电子发烧友网站提供《GT2440嵌入式开发系统用户手册.pdf》资料免费下载
    发表于 10-28 17:05 2次下载

    恩智浦如何攻克两大嵌入式开发难题

    在我们的身边,嵌入式系统无处不在。而随着技术的进步和应用的拓展,今天的嵌入式开发也面临着诸多新课题、新挑战。
    的头像 发表于 10-27 09:28 2165次阅读

    嵌入式开发平台 AMD嵌入式软件和工具2025.1版现已推出

    AMD 2025.1 版嵌入式软件和工具是面向新嵌入式系统开发而打造的综合平台,全面加速概念构想到部署落地。 2025.1 版嵌入式软件
    的头像 发表于 08-20 09:15 4354次阅读

    嵌入式开发就业还有前景吗?

    。在智能家居领域,嵌入式开发的主要工作是开发各种智能化设备和系统,如智能照明、智能安防、智能家电等。嵌入式开发人员需要掌握相关的硬件和软件技术,如处理器、传感器、通信技术、操作系统等,同时也需要具备
    发表于 07-16 10:47