这篇文章在无数技术网站都找的到。我在这里发这篇文章的原因:

1。这篇文章实在很好。别说作者倾情的介绍了自己的经验和感想(尤其是关于“钱途”的感想),里面介绍的一些书,真够有志开发驱动程序的同志看半辈子了。

2。我搜索了文档中心,没有发现这篇文章。

3。我现在需要参与分给我的帖子加分(可用分700多可是参与分没有了),大家多多点击  :)

》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》

我的DDK学习经验
转载辅大美少女梦工场BBS站

自从97年1月我在Program版Post鼓励有心网友学习Window Device Driver以来,陆续收到一些人询问如何下手.现在我已没时间玩BBS,因除了3D显示卡Driver要Tune外,还被派去做一些杂7杂8的事情.趁教师节比较有空,写下这封我学习DDK的经验,如果那站的站主觉得对网友有帮助,就尽管利用,不用客气.但需注明出处,并严禁有任何谋利举动(如剽窃修改后,来赚取稿费),曾对一些网友提出如何在MFC中用I/O Port Function的问题,回答了6次,让我觉得很烦烦烦烦烦烦,希望这种情况不在发生.

本文供分3段:(1)为何我要学DDK (2)学习DDK的过程 (3)未来可能的发展.

(1)为何我要学DDK.

我是资讯科班出身,就读过交大计工,清大资研.历经78,79股市狂飚,退伍后,认为写程序没什么前途,也无法撑到38岁.但MBA却是越老人脉越多,收入也越多,所以进资策会,一面工作一面准备GMAT,但没申请到理想的学校,而考外贸协会的人才培训班,在复试时也被刷下来.最后认命乖乖学Window 3.1,第一年做多媒体资料库专案,当时连VC++ 1.0都还没出现,就用Borland C++ 3.0以纯SDK方式coding,(因不知道有OWL这种东西)事后想起来真是因祸得福,让我更了解Window底层的运作(不过当时真的觉得很干).

第二年做Video Editor是我比较快乐的时光,VC++ 1.0刚出来,但市面没一本相关书籍,连MSDN也一样.怎么办?到处找不到资料.最后用最笨的方法:用Debuger trace MFC source code!, 然后搭配Video for Window 1.1版SDK来coding,当时傻傻得,以为可以做个Video Editor跟友立拼,所以常常加班到10点,但后来Video Editor结案后就放到储藏室,而Aldus被Adobe并购,友立也把PhotoStyle卖给Adobe.这件事件让我得到个教训:套装软件不好做,更难与国际大厂同类型产品竞争.因有时Video Editor会利用MCI Command来控制AVI/FLI播放,但觉得很奇怪,那个MCI Driver到底在搞什么鬼?在好奇心驱使下,翻MSDN的MultiMedia Device Driver来看,才搞懂MCI Driver如何与底层的Video/Audio Driver沟通.

第三年是最黑暗的时期,Team Leader包个Multimedia Title来做(还曾打算向敦煌科技包Game来做).美工,企划,全和在一起,而要我用Director 3.0的Lingo语言来写Title的Program.我便开始消极抵抗,同时自己偷偷用MFC+WinG+32Bit Assembly在Win3.1上写个类似Director3.0的Engine. UI及绘图引擎都完成,而且播放速度比Director 3.0还快.但卡在不知道如何设计Script及Interpreter.最后只好做罢.然而转捩点就发生在这一年:应台北电脑工会之邀,开门"Windows影音驱动程序剖析"课程而与童子贤先生有一面之缘(当副总的他竟跑来上我这无名小卒的课),也保留他一张名片.另外帮别人写Motion Control Card的Dos Driver来用在CNC上,对Driver开始发生兴趣,原来写Driver的利润颇丰.

第四年,黑暗的日子终于过去.参与IBM VisualAge for Basic的Visual Component开发,用VisualAge for C++ 3.0来coding,过了一段无任何相关资料的日子,还好从李维那拿到OpenClass source code,发挥tracing的精神,终于顺利结案.这年在某电脑展中遇上任职IBM的大学同学,被他讥笑还在米仓中当米虫,让我心理不好受.也使我思考,只会coding的我未来要何去何从,难道要过着一年换一个专案的日子吗?然后40岁时会变成怎样?(PetShop Boy的"Being Borning"在我脑中响起...).

幸好碰上一个影响我很大的同事,他那时也刚帮人写完一个Window 95的VxD,于是向他讨教,并学得如何收集相关资料,练好后就接个A/D,D/A卡的Win31/95 Driver CASE来做,写完Win95觉得不过瘾,便拿NT4.0 DDK来看.另外他有事没事拿ASIS电子周刊给我看,当时正报导PC97的specification:ACPI,AGP,OnNow等新技术,我看完就知道大好机会来了.凭做A/D, D/A卡Window Driver的经验,我知道随着Win95的普及,这些硬卡没有Win95 Driver根本很难卖到欧美.PC97规定了Intel的硬件设计如何跟Microsoft的Window做结合,而接口就是Window Driver!,加上主机板厂养的软件工程师只会写BIOS or 8051,对Window Driver根本是听都没听过,但PC97,98是必走的道路,所以一定要找到会的人来做.

而这时候我又要换另一资料库相关的专案(我最讨厌做MIS,成天与数据,报表奋战,有够无聊).于是上网路找工作,想到手头的童子贤名片,就试投华硕看看.没想到一试便上,(不过在面试时被嫌在资策会待太久,恐染上不良习性).进华硕后,感觉到是Right Man in Right Place.终于可以一展抱负,有明确的目标,不再虚度时光,也不会被别人嘲笑是米虫.更重要的是有成就感,想想做的专案,是要卖到全世界的产品,而且是与一些国际大厂竞争产品上市时间.再也不是作完往仓库一摆的东西.再者华硕目前员工人数少,业务扩展迅速,加上公司高级领导阶层非常重视研发实力,只要有能力的人,不怕没升迁机会.不像宏基已有太多员工,没什么表现能力的机会,且升迁管道太挤了

(2)学习DDK的过程

要学DDK首先要把Window的底层基础练的扎实.但一般人对学Window SDK都视为畏途,更何况是底层的东西.从Win31到Win95变化比较多得,我个人认为是:Multitasking,Plug&Play,Memory Addressing.有人问我说,Memphis都快出来, 还要花功夫看Win95 or Win31吗?, 我认为还是要!原因是:

a.Memphis不是完全重新改写,里面的一些观念还是沿用Win95.
b.目前市面上尚未有大师级的Memphis相关书籍,如果有也只是趁火打劫类型的书,而台湾的书商,作者最会搞这种把戏来A钱.如Win31/95方面已有一些大师的书籍,如Andrew Scrullman,Patt Metrick,Richard Jeffery,Walter O'ney,Charle Patzold等大师.你不去看大师级的书,反而去看"快快乐乐学Memphis","教你21天学会Memphis"这类垃圾书,真是在浪费你的时间及金钱.

学DDK的第一步准备功夫是把英文阅读能力练好,你别指望书商会出中译本.因这类书的卖相太差,比不上VB,Delphi,JAVA这类较大众化的书.再者要找到够格的译者很难.要译好是要花相当时间,那还到不如去写些轻松的书,稿费也赚得多.

接下来就要练基础工夫,如同张无忌花了6年时间练好九阳真经,等到练乾昆大挪移时只花数个时辰就OK.要如何练底层基础呢?勤看书,勤coding及Trace别人写得sample code而已.即使是天才型的Programmer也是要看书,因Window不是他设计的,必须了解Window才有办法下手.而非像写Algorithm方面的论文般,自己定assumption, Lemma,导出Theme,下conclusion就完成.所以一些刚入社会的研究生最好先调整自己的心态.

以往我是读一些大师级的书,如:
"Window Programing"的CharlePetzold,
"Undocument Window"系列的Andrew Scullman,
"Win95 system Programming Secrets"的MattPietrek,
"AdvancedWindows"的JefferyRichter.

期刊的话是:
Microsoft System Journal,
Doctor Dobb's Journal,
Window Developer Journal这本期刊是我认为学DDK的人必要订阅的!几乎过个1,2期就会刊登Window Device Driver相关的文章,而且里面有位Paula女士主持的NT专栏,写的很深入,不是市面一些标榜NT"大剖析"之类的书籍所能比拟.在Andrew Scrullman的"Undocument NT"尚未问世之前,它是我觉得最有深度的专栏.

接下来就谈与Driver有直接关系的资料:

Device Driver的书籍,我从Win31开始说起:
"Writing Windows Device Driver and VxD",Karen Hazzen,第1,2版是最适合写Win31 Driver的参考书籍.也有一本白皮的"Writing Window Device Driver",我认为它的参考性很低,因它光抄Win31 DDK Function Description就花了50~60几页,有A钱之嫌.

Win95:
那当然是首推"System Programing for Win95",Walter Oney.

这本巨作.我曾因翻Chapter11~13翻到书页掉落,而重新再买一本.Walter Oney既出,谁与争锋.有这本就够了!也没有人有胆来挑战他.

WinNT:
唯一的一本:"The NT Device Driver Book",Art Baker.很有系统的一步一步介绍如何写NT Kernal mode driver.先看这本书然后再看MS的NT DDK on Help会让你较容易了解.当初没这本书时,我刚开始看DDK Help是看得满头雾水.最好搭配"Inside Windows NT",Helen Custer一起看,因为NT底层已经导入Object Oriented观念(WDM是将NT Kernel mode driver 加装Plug&Play及Bus handle等新功能),与Win95的Virtual Machine观念相差甚远.这本书虽是1992年出版,但有对NT的核心运作加以介绍,也是一本难得的好书.

NewGroup and WebSite:
1.Win95是comp.os.ms-windows.programmer.vxd
2.NT的话是comp.os.ms-windows.programmer.nt.kernel-mode
3.Window Device Driver Web site:
http://www.albany.net/~danorton/ddk
http://www.vireo.com

发展工具:
1. 如何要让你日子好过,一定要有套SoftIce for Win95/NT.千万不要用MS的WinDebug,它根本是无山晓路用.SoftIce可让你用source code level debuging,对有assembly恐惧症的人是一大福音.(但我还是劝有心学DDK的人还是要摸assembly).

2.VToolsD(for Win31/95),DriverWork(for NT/WDM)
Vireo公司出的DDK Tool让你完全用C来写Driver,我只能说写Driver时,我已经不能没有它.由其它还免费附Class Library source code,让我Trace的很高兴.

领域知识(Domain Knowledge)
写Driver需了解你要控制的硬件,如Driver有用到DMA/Interrupt,建议你看一下8259,8237A的资料.在这方面,"微电脑接口技术与应用"是本不错的参考书. Programmer总有一天会coding不动的时候.但人老成精,只要你的Domain Knowledge够强的话, 还是会有许多公司请你去当技术经理, 而这也是你能克死年轻力壮Programmer最大的本钱. 多多看些其他杂志, 接触一些非Programming方面的知识来培养你的Domain Knowledge吧!

最后最重要的是:亲自动手做做做做做做做做做!
看资料是一回事,知道是一回事,做的出来又是另外一回事.公司请你来不是要听你长篇大论,或是发表多少篇论文.是要你做个会动,能商品化的东西.等你做下去,踢到铁板,又找不到别人问,也没有任何资料可帮助.再加上硬件没你写的Driver而无法出货时,那种滋味可是人间炼狱.我就遇上一次,东西都出到俄罗斯,德国的经销商时,结果发现Driver有Bug,无法顺利安装.老大放话说一星期内没解决,俄罗斯经销商就要取消订单(天呀!几百万美金的交易),我在想,如果到时解不掉就准备辞职.后来真是狗屎运.用一个非常另类的做法(骑摩托车在半路上想到的),解决这个Bug,保住订单也保住职务.说这则例子主要是奉劝一些自视甚高的在学研究生,不要以为顶着高学历,就可以在社会上一帆风顺(除非窝到学校或财团法人,政府机构内),也鼓励一些没有傲人学历的网友,只要有实力发挥黑手精神,照样可以当主管来管一群硕士工程师.

(3)未来可能的发展

看看WinTel PC98的规格,就知道以后会写Driver的人比较吃香,目前会用C,SDK写程序的人不多,更何况是写Driver,其实Driver并不难写,只是Learning curve很长,现在大多初学者怕难没耐心,都用VB,Delphi这类RAID Tool来写程序, 都快不知道SDK是何物.更不用说Window内部的运作.除非是走MIS路线,否则以后日子会很难过.就现实面来看:用VB,Delphi的人太多,老板要找个人来取代你的职务是很容易得.就盈余而论,国内做MIS的公司比不上做PC硬件,Chip set的公司,而且也没有股票可分,何苦去挤到经济规模小又人数众多的领域内.(但Year 2000对MIS工程师可是个大利多,只不过你还要会一些非常古老的程序语言,而不是懂VB,Delphi就没事).就我观察的结果: 目前主机板的软件工程师大都只会BIOS, 8051.根本都不懂Windows Driver.不要以为写个soft menu的BIOS就扬扬得意.等PC98正式上场就有好戏看.所以在这些公司中有有太多机会来让你表现自己的能力.

感想:
国内一些电脑作家实在是太好混日子,可以从VB写到VC,然后还可以"深入探讨"3D加速卡.流行VB就出VB的书,一本号称VC++/BorlandC++圣经的书,竟然都没提到MFC/OWL.而Windows95一出来,书摊又是一堆Win95圣经宝典之类的中文书.等着看吧,明年Memphis出来时又将旧事重演.不只如此,还故意标榜有博士学历或具有写作10几年的经验来烘抬自己的身价.有时我看了就一肚子火.不过这些人还不是照样继续A钱.真是......,而国内一些电脑杂志的水准,大家心理有数,不用我多讲.值得我佩服的,大概只有侯俊杰,不过最近一年他好像都只写MFC相关的文章书籍,没写些Windows内部运作的文章,不知这是否跟上次Matt Pietrek来台有关.
总归一句话:读者要自己小心,少碰一些"圣经,宝典. 最后,

祝大家能找到心目中理想的工作.

我的DDK学习经验(转载)相关推荐

  1. DDK学习笔记(转)

    下面这是kruglinski关于学习驱动编写的文章.虽然是入门级文章,但是也需要对驱动有一些了解后才可以看的比较透彻. <DDK学习笔记>1---入门 1.驱动程序的结构: 1.1.一个入 ...

  2. C# .NET学习经验总结

    1. 装箱.拆箱还是别名 许多介绍C# .NET学习经验的书上都有介绍 int -> Int32 是一个装箱的过程,反之则是拆箱的过程.许多其它变量类型也是如此,如:short <-> ...

  3. 架构师成长之路-个人学习经验分享(公司研发峰会演讲ppt)

    前天在公司分享了一些学习经验,园子中感兴趣可以看看.建议大家使用pptPlex来看这个片子. 首先从我在成长中不同阶段的工作和体会来谈不同阶段的学习内容谈起,为了做好这些必修课,我会对知识+实践+思考 ...

  4. 小白一路走来,连续刷题三年,谈谈我的算法学习经验

    数据结构与算法应该算是一个比较难的模块,从小白一路走过来,从大一连续刷过好几年题,看过挺多书,踩过挺多坑,也涨了一些经验,姑且在这里分析一波对数据结构与算法 的学习经验,请耐心看完,相信对你会有所帮助 ...

  5. WCF分布式开发步步为赢(0):WCF学习经验分享,如何更好地学习WCF?

    WCF分布式开发学习,应该从哪里开始? 微软WCF Web服务 Web API学习群 339444457 微软ASP.NET MVC 4 Web编程群     44206115 学习WCF是不是就不需 ...

  6. KMP算法的学习经验

    KMP算法的学习经验 (欢迎指正错误, 欢迎喷) 什么是kmp(完) kmp的额外知识(完) 暴力匹配的缺点,和代码实现(完) next[]数组的预先知识,了解前后缀,相同前后缀.(完) kmp的关键 ...

  7. [zz]WCF分布式开发步步为赢(0):WCF学习经验分享,如何更好地学习WCF?

    WCF分布式开发学习,应该从哪里开始?    学习WCF是不是就不需要学习Enterprise Sevices(COM+).Net Remoting.Web Service(ASMX).WSE3.0和 ...

  8. 如何学习前端 转载

    作者:小不了 链接:https://zhuanlan.zhihu.com/p/23265155 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 鉴于时不时,有同学私信 ...

  9. OpenStack - 学习经验总结

    经过一段时间OpenStack学习,从最初的挣扎到现在的实施部署,太多需要总结的东西,在这里啰嗦几个学习经验总结,帮助大家少做弯路,更好的学习理解. 学习习惯: 1) 从I版到K版的学习中,遇到了各种 ...

最新文章

  1. bean ref的bean可以做判断吗_Spring Boot @Condition 注解,组合条件你知道吗
  2. 特约专栏丨陈纯院士:大规模动态时序图实时处理技术、平台及应用
  3. windows操作系统自带的TCP端口转发
  4. appid 参数错误_辽宁罗茨风机参数
  5. cpu序列号唯一吗_手机CPU天梯图2020年1月最新版 你的手机处理器排名高吗?
  6. 网狐棋牌游戏平台服务器架构设计分析
  7. 客户端与服务端的TCP通信实现(Qt)
  8. java多字段排序,java8 stream多字段排序的实现
  9. SPI和RAM IP核
  10. 阿里P8架构师谈:开源搜索引擎Lucene、Solr、Sphinx等优劣势比较
  11. Docker实践(七)部署SpringBoot微服务
  12. Exchange2016-抢先体验
  13. delaunay三角网构建
  14. 32位汇编(1) - masm32环境配置
  15. 龙芯3A3000上实现BLFS的轻量级桌面LXDE
  16. video标签使用controls属性怎么去掉三个点
  17. 浅谈国内域名注册商与国外域名注册商的区别与优势
  18. 对于ACM竞赛算法分类的整理
  19. 全国2013年10月考试《行政组织理论》试题和答案
  20. 你是否在Microsoft Edge上测试你的网站?

热门文章

  1. java中dateFormat是什么_Java中的DateFormat用法举例
  2. 二叉树学习的一些个人心得
  3. java走梅花桩_西非海牛吃上粤式团圆饭 留粤过年家庭齐捞“风生水起”
  4. winform show()和showdialog()区别(转载)
  5. APP、微信小程序、网页H5
  6. 概率与期望,成为预言家的第一步
  7. linux wc -l的含义,linux wc 命令简介
  8. [paper]Adversarial Transformation Networks: Learning to Generate Adversarial Examples
  9. 21. 合并两个有序链表 JavaScript实现
  10. 【Linux篇】sed命令详解