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

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

3天内不再提示

宋宝华:一种非常经典简单的设计模式——模板方法

Linux阅码场 来源:lq 2019-01-14 16:05 次阅读

前言

《设计模式》这本经典的书里面定义了20多种设计模式,虽然都是面向对象的,似乎需要C++Java这样的语言才能实现,但是根据笔者前面反复强调的,Linux内核虽然是用C语言汇编语言写成,但是其实也到处充满了面向对象的设计。面向对象更多的是一种思想,而不是一个语言。我们可以用C语言实现极大的OO,Linux内核到处都有OO。

模板方法

比如,在Linux的设备驱动框架中,就用了一种非常经典简单的设计模式——模板方法(Template Method),当然还有一些其他的设计模式。而设计模式牛逼的地方在于,高手往往不经意之间已经用到了设计模式,甚至自己都不知道。如果高手没有系统地学习过设计模式,这其实不见得是一个问题。这并不意味着它不懂设计模式,只是他自己都不知道自己用到了哪个模式。而设计模式学习的终极目的,当然也是忘记设计模式,这个跟练独孤九剑没什么区别,到最后其实是无招胜有招。

模板方法这个模式,强调定义一个基类,这个基类实现了通用的流程和算法。比如做一件事情需要经过step1()、step2()、step3()。那么我们定义一个基类:

而其中的step1()、step2()、step3()、step4()具体如何实现则是因人而异,所以我们从baseClass类里面,继承出来的类里面,实现step1()、step2()、step3()这样的代码,override掉baseClass里面的函数。

这样的设计让外部不关心derivedClass,因为流程和接口都是在基类的。而基类实现的doSomething()成员函数,是对外的接口。这个UML关系是非常简单的:

驱动案例

在Linux设备驱动里面,大量存在类似的设计,我们以NAND为例子。在drivers/mtd/nand/nand_base.c这层里面,定义了NAND的一些操作流程。

比如写OOB的代码:

它这个里面要走cmdfunc()、write_buf()、cmdfunc()、waitfunc()这些步骤,这些步骤,不管是全世界哪个NAND的硬件,都是一样的通用的,但是具体的不同的NAND硬件控制器,实现这些步骤中涉及到的cmdfunc()等函数的实现方法却因人而异。

譬如freescale的版本fsl_elbc_nand.c就是:

nand_base.c这个C文件是NAND的中间层,它非常类似我们前面说的实现baseClass这一层的代码,nand_write_oob_std函数类似baseClass :: doSomething。而Linux驱动中定义的nand_chip的各个不同的NAND控制器,对nand_chip这个结构体中成员函数cmdfunc()、write_buf()等的实现则是各异的,类似derivedClass里面override掉step1()、step2()。nand_chip定义在include/linux/mtd/nand.h:

这样的设计,好处是非常明显的。特定的硬件只用管与自身操作相关的事情,而通用的流程,都由nand_base搞定,最大程度上减小了具体实例的代码量,也最大程度上复用了中间层的代码。

这样的例子无处不在,比如我们在LCD的中间层:

后语

本文后语不搭前言,请见谅。最近有很多童鞋询问笔者,做Linux驱动有没有前途?笔者明确地告诉大家:根本没有前途!但是前途是自己赚的,这依赖你从驱动进去,但是从更大的视角出来:

1.通过做驱动理解很多OO的架构设计思想,升华自己高内聚和低耦合的理解,把自己变成一个更高level的software engineer;

2.通过做驱动,进一步理解Linux本身的进程、内存、IO等知识,升华对软件系统和性能分析的理解,把自己变成一个更高level的技术expert。

如果做了5年驱动,进入的时候是调试寄存器示波器,出来的时候还是调寄存器搞示波器,那自然是完全没有什么前途的!

有没有前途,这个事情,完全是因人而异的。前途是无所谓有,无所谓无的。你如果有抽象、衍生的能力和不断学习总结的精神,无论是做驱动还是不做驱动,都会是很有前途的事情。反之,做什么基本都没前途。

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

    关注

    87

    文章

    11298

    浏览量

    209396
  • C语言
    +关注

    关注

    180

    文章

    7604

    浏览量

    136748

原文标题:宋宝华:Linux设备驱动框架里的设计模式之——模板方法(Template Method)

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

收藏 人收藏

    评论

    相关推荐

    一种简单的可控硅好坏判断方法

    一种简单的可控硅好坏判断方法
    发表于 07-28 08:17 6291次阅读

    一种简单的OpenHarmony环境搭建方法

    本文介绍一种简单的OpenHarmony环境搭建方法
    的头像 发表于 03-14 13:58 3425次阅读
    <b class='flag-5'>一种</b><b class='flag-5'>简单</b>的OpenHarmony环境搭建<b class='flag-5'>方法</b>

    一种简单的逆变器输出直流分量消除方法

    逆变器输出直流分量会对逆变器本身和交流负载产生不利影响,必须消除直流分量来保障逆变器的可靠运行。提出了一种简单的消除输出直流分量的方法,并在理论分析的基础上,通过对1台220V、1 kW的逆变器系统
    发表于 12-27 11:20

    清远见教程

    《Linux按键和LCD设备驱动》主讲老师:清远见企业学院讲师,视频要点:1、Linux按键和触摸屏驱动和应用编程;2、LinuxLCD驱动和应用编程。《Linux按键和LC
    发表于 04-10 11:48

    _精通LINUX设备驱动开发

    的这本书就不要我介绍了。
    发表于 07-06 21:03

    一种改进的自适应模板匹配法

    本文提出了一种基于数据流修正的自适应模板匹配定位方法。该方法首先在图像预处理的基础上,进行模板匹配,从而定位待识别目标;然后采用数据流修正的
    发表于 08-17 08:05 21次下载

    模板方法模式在回溯算法中的应用

    描述了模板方法模式及回溯算法的模板方法模式的Java 语言实现,该实现使得回溯算法的实现达到了可
    发表于 01-15 16:51 0次下载

    STEP模式映射的一种实用方法

    STEP模式映射的一种实用方法 在STEP标准的应用中, 常需要通过不同STEP应用协议之间或其中某应用协议的不同视图之间的映射来实现异构系统间的数据交换。本文提
    发表于 02-22 14:37 10次下载

    基于模板匹配的电子元器件针脚检测方法

    相关系数法模板匹配是数字摄影检测中的一种经典的基于灰度的匹配方法。提出了一种基于模板匹配的电子器
    发表于 08-02 14:12 19次下载

    一种基于STM32的SMS短消息收发系统_

    一种基于STM32的SMS短消息收发系统_
    发表于 01-14 22:32 0次下载

    一种针对DoT算法的模板攻击方法

    模板攻击是一种重要的侧信道分析方法,其在实际密码算法破译中具有较强的区分能力。轻量级分组密码算法DoT在硬件和软件实现中都表现岀优秀的性能,尽管目前针对DoT算法的传统数学攻击已经取得了
    发表于 03-21 10:34 8次下载
    <b class='flag-5'>一种</b>针对DoT算法的<b class='flag-5'>模板</b>攻击<b class='flag-5'>方法</b>

    一种针对DoT算法的模板攻击方法

    模板攻击是一种重要的侧信道分析方法,其在实际密码算法破译中具有较强的区分能力。轻量级分组密码算法DoT在硬件和软件实现中都表现岀优秀的性能,尽管目前针对DoT算法的传统数学攻击已经取得了
    发表于 03-21 10:34 12次下载
    <b class='flag-5'>一种</b>针对DoT算法的<b class='flag-5'>模板</b>攻击<b class='flag-5'>方法</b>

    设计模式行为型:模板方法模式

    模板模式中,个抽象类公开定义了执行它的方法的方式/模板
    的头像 发表于 06-07 15:13 585次阅读
    设计<b class='flag-5'>模式</b>行为型:<b class='flag-5'>模板</b><b class='flag-5'>方法</b><b class='flag-5'>模式</b>

    非常经典的FPGA设计方法论.zip

    非常经典的FPGA设计方法
    发表于 12-30 09:22 3次下载

    一种简单高效配置FPGA的方法

    本文描述了一种简单高效配置FPGA的方法,该方法利用微处理器从串行外围接口(SPI)闪存配置FPGA设备。这种方法减少了硬件组件、板空间和成
    的头像 发表于 10-24 14:57 569次阅读
    <b class='flag-5'>一种</b><b class='flag-5'>简单</b>高效配置FPGA的<b class='flag-5'>方法</b>