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

    文章

    10988

    浏览量

    206724
  • C语言
    +关注

    关注

    180

    文章

    7528

    浏览量

    128396

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

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

收藏 人收藏

    评论

    相关推荐

    一种电子系统测试性模型的研究

    【作者】:东;胡立;朱道德;王传清;【来源】:《测控技术》2010年03期【摘要】:测试性是系统和设备的一种便于测试和诊断的重要设计特性,对现代的航空电子设备、武器装备等复杂系统的维护性、可靠性
    发表于 04-22 11:28

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

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

    非常经典的FPGA设计方法

    非常经典的FPGA设计方法
    发表于 08-07 16:11

    清远见教程

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

    [分享资料]linux设备驱动开发详解_

    `、看威武霸气的封面作者: 二、读读简介,看看适合你吗?这是本介绍Linux设备驱动开发理论、框架与实例的书,《Linux设备驱动
    发表于 09-11 23:36

    _精通LINUX设备驱动开发

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

    Linux建议的学习方法

    : 迭代螺旋法——关于Linux学习方法的血泪建议
    发表于 04-15 11:38

    一种Discuz2.5模板样式?

    一种Discuz2.5模板样式?有哪位大神能分享
    发表于 07-05 06:03

    怎样去新建一种基于STM32CubeMX的模板

    怎样去新建一种基于STM32CubeMX的模板?有哪些流程?
    发表于 09-29 08:32

    介绍一种简单的数据解析方法

    JSON。​ 下面我将介绍一种简单的数据解析方法,通过编写函数,将字符串解析取得目标数据。解析字符型数据函数原型/*** @brief从段字符串中解析期望的字符串* @parampB
    发表于 02-28 06:15

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

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

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

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

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

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

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

    模板模式中,一个抽象类公开定义了执行它的方法的方式/模板
    的头像 发表于 06-07 15:13 401次阅读
    设计<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次下载