`
webcenterol
  • 浏览: 951005 次
文章分类
社区版块
存档分类
最新评论

编程本质论

 
阅读更多

编程本质论<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

by leezy_2000

这几年各种新的技术井喷一样的涌现出来。身处这样一个时代的我们,难免就有一种拔剑四顾,心下茫然的感觉。在某一方面的做到精专已属不易,全才似不可能,那么究竟又该何去何从?这篇文章目的是探讨编程过程中一些本质的东西,已期对大家的学习有所帮助。

个人以为,从编程这一职业诞生开始一直至今,其本质就没有改变过。对概念的抽象对逻辑的描述始终都是编程过程中最核心的东西。

程序为解决某一问题而存在。而问题可拆分成某些概念和逻辑关系。而结构化程序设计和面向对象程序设计不过是对概念和逻辑进行表达的不同方式。而程序中逻辑关系的复杂程度随程序的规模而增加。

程序的本质不是各种技巧。就算你把Effective C++,More Effective C++中的每一条款都应用到了你的C++程序中,如果没有对逻辑关系的良好组织,你的程序也可能糟不可言。可能高耦合低内聚,可能不可扩充―――。

上面这段文字提到了四个概念,他们分别是:问题、概念、逻辑和技巧。

我来举个例子来说明这四个概念都代表些什么。

现在假设我们需要根据已知的一个文件名产生一个临时文件名。如果输入为prog.dat,mydir,hello.,oops.tmp,end.dat那么相应的输出为

prog.dat=>prog.tmp

mydir=> mydir.tmp

hello.=>hello.tmp

oops.tmp=>oops.xxx

end.dat=>end.tmp

(这里使用了The C++ Standard Library中第11章的例子)

什么都不做的程序是不存在的,程序总要解决客观世界中的某些问题。这里的问题就是要为一个已知的文件名产生相应的临时文件名。

解决这个问题时涉及的概念主要有两个:字符串和扩展名。扩展名可以用字符串进行表示。

解决这个问题的逻辑之一可用下面的伪代码来表述:

if(输入文件名没有扩展名)

{

用输入文件名、'.'号和"tmp"生成临时文件名;

}

else

{

得到输入文件名的扩展名;

if(扩展名为空)

{

用输入文件名和"tmp"生成临时文件名;

}

else if(扩展名为"tmp")

{

把"tmp"替换为"xxx";

}

else

{

把文件名'.'以后的部分替换为"tmp";

}

}

当然你还可以有其他的实现逻辑,而这种逻辑总是可以独立于语言、操作系统的。

至于你是用C++标准库、还是MFC的Cstring类或者.net中的相应类或者不依靠类库自己用某种语言来表述这种逻辑那就是技巧

上面虽然是个小例子,但我认为完成任何程序:从上层应用直到底层驱动,都会涉及到这四个概念,。

上面所说编程时必须的四个要素中,我个人认为逻辑和概念是编程中更本质的东西,直接的原因是他们在更大的程度上决定着程序的质量。不要忘了评价软件质量的几个指标:

健壮性、可重用性、易扩充性、容错性等。

而这些指标并不是你选择了某个语言或者某个框架他们就达到了。而要通过对解决的问题的逻辑进行提炼和精化才可能达到。不要说这是系统分析的责任,程序每一部分都有自己要解决的问题,怎么可能每一部分程序质量的保证都是系统分析的责任。

此外当你要把原来用软件实现的功能换做用硬件来实现的时候,这点就分外的明显--软件其实就是一组逻辑关系。

但眼下主流意识形态似乎并不认同这点,各种招聘广告可为明证。

下面是一个招聘软件工程师的广告:

1. BS degree or above in computer science.
2. At least 2 years of driver development experience.
3. Experience in C, C++, windows SDK/DDK or Linux system development.
4. Familiar with computer networking or telecommunication 802.3, 802.11, TCP/IP protocol is a plus.
5. Familiar with embedded system design.
6. Familiar with Bluetooth is a plus.

如果把编程与磨刀砍柴做类比的化,那么

当某个人熟悉某种语言、某个框架、某个IDE、某个协议某个开发包的时候我们可以认为这个人拥有一把较锋利的柴刀。但这和这个人最终擅不擅长砍柴并没有必然的关系。夫欲善其事,必先利其器。但利其器了未必就会善其事。所以说上面的广告一定程度上相当于想找一个会砍柴的人,但看人的时候却更注重他有没有一把锋利的刀子。(更可悲的是挣扎在生存边缘的我们,纵然不愿却也不得不迎合这种要求)

未避免矫枉过正,这里要强调一点,不是说基本技能不重要,没有对语言、框架、IDE的一定认识,根本就产生不了有用的程序。但当我们执迷于对不同语言、框架、IDE的优缺点进行比较的时候,不要忘了他们并不对程序的健壮性、可重用性、易扩充性、容错性等最终衡量程序优劣的诸多方面起决定作用。起决定作用的是你对概念的定义方式和对各种复杂逻辑关系的描述方式。

语言是什么?语言是逻辑的载体和描述的工具。当你试图表述逻辑关系的时候大多语言应该是满足这一要求的,要不然他早被淘汰了。框架是什么?框架是对逻辑和概念的一种封装。框架把某一领域通用的概念和逻辑封装起来,进而使程序员不必做一些重复性的工作。而实际上对这个领域的这些通用概念并不只有这么一种表述方式,也就是说并不只有一种逻辑表述。你选择某个框架的同时也就意味这你从n种方式中选择了一种,舍弃了其他。没有那个框架是完美的,选择的同时自然也就继承了这种不完美。所以善用他们,他们很重要,但不会再重要了。

当我意识到这点时,我发现虽然编程许久,但在对逻辑表述方面的能力却没有寸进,因为把90%以上的时间都投在了技巧的提升上了。Jeffrey Richter和Matt Pietrek两位堪称Windows编程界中的技巧大师。可我现在敢说即使你把《Windows核心编程》、《Programming Server-Side Application for Micorsoft Windows 2000》还有MSDN杂志的Under the Hood专栏倒背如流,你可能还是写不出高质量的程序。这些东西是必须的,但远不是全部。

林锐写过一本《高质量C++/C编程指南》,此书在网上流传甚广,我想原因有二:一是此书对C/C++语言中的容易造成模糊的地方进行了详细说明(真的很有用);二是林锐笔法不错。但也正因其流传甚广,我觉得在这里必须指出,此书严重的文不对题。按照书中所说那些就能设计出高质量的C/C++程序么?那些都是编程所需要的技巧,不过是告诉你怎么能磨出一把锋利的刀而已。如果读过此书的人都把这些技巧和高质量的程序相等价,那么学习时恐怕就难免会误入歧途了。

这个题目太大,我是姑妄言之。这里不过是刚刚开始一种探讨而远非结论。欢迎大家一起讨论,还望诸君有以教我!

分享到:
评论

相关推荐

    C#本质论(中文版).pdf

    《C#本质论》是一本深入探讨C#编程语言核心概念和技术的中文书籍。C#是由微软公司开发的一种面向对象的、类型安全的编程语言,主要用于构建Windows平台上的应用程序,尤其是.NET框架下的应用。这本书旨在帮助读者...

    C#本质论(中文版)_C#本质论+第4版_C#本质论_c#本质_

    《C#本质论》是C#编程领域的一本经典著作,尤其在中文环境中深受程序员的推崇。这本书深入探讨了C#语言的核心概念、特性和设计哲学,为读者提供了全面而深刻的C#学习资源。第4版更是对原有的内容进行了更新,以适应...

    c#7.0本质论带图片完整版

    《C# 7.0 本质论》是一本深入探讨C#编程语言核心概念和技术的书籍,高清彩色扫描版提供了良好的阅读体验。该版本包含了完整的图文内容,旨在帮助读者全面理解C# 7.0的新特性和编程理念。C#是微软开发的一种面向对象...

    C_本质论(中文版).rar

    《C#本质论》是C#编程领域的一部经典之作,专为想要深入理解C#语言的程序员设计。这本书详细地介绍了C#的核心概念、语法结构以及编程实践,旨在帮助读者掌握C#的本质,从而更好地利用这一强大的面向对象语言进行软件...

    《C#本质论》

    C#本质论第3版提供了详细的编程教学,您可以让您在书籍上学习到C#语言相关的开发内容,让您在编程的时候获得更多技巧,书籍的内容很多,您可以学习匿名类型、自动实现的属性、集合接口、匿名类型和隐式类型的局部...

    C#本质论中文版+英文版,pdf

    《C#本质论》是一本深入探讨C#编程语言核心概念和技术的经典著作,分为中文版和英文版。这本书由著名编程专家撰写,旨在帮助读者理解C#语言的本质,从而更好地运用到实际开发中。以下是对书中主要知识点的详细阐述:...

    《COM本质论》

    《COM本质论》这本书深入剖析了COM技术的核心概念、设计哲学以及实现机制,是理解COM编程的关键参考资料。 在COM组件的核心原理中,首先要了解的是接口(Interface)。接口定义了一组方法,但不包含具体的实现,是...

    C#本质论(中文版)

    《C#本质论》是一本深入探讨C#编程语言核心概念和技术的著作,中文版的出版使得更多国内的开发者能够无障碍地学习这门强大的编程语言。本书主要涵盖了以下几个关键知识点: 1. 继承:继承是面向对象编程的重要特性...

    C# 6.0本质论 第5版

    《C# 6.0本质论 第5版》是一本深度探讨C# 6.0编程语言核心概念和技术的专著。此书旨在帮助开发者深入理解C# 6.0的精髓,提升编程技巧和效率。书中涵盖了C# 6.0的最新特性和改进,包括增强的语法糖、异步编程、类型...

    C#7.0本质论_EssentialCSharp-7.0 源码 - 2020新版.zip.zip

    《C# 7.0 本质论》是针对C#编程语言的一本深入解析书籍,尤其对于想要深入了解C# 7.0新特性的开发者来说,这是一个宝贵的资源。该资源包含源码,使得读者能够结合理论与实践,更好地理解C# 7.0的核心概念。 C#是...

    COM本质论附书源码

    《COM本质论》是侯捷先生撰写的一本深入解析COM技术的专业书籍,这本书深入浅出地讲解了COM的核心概念、设计哲学以及实现机制,对于理解和掌握COM技术具有很高的价值。 在《COM本质论》中,侯捷先生通过理论与实践...

    COM本质论图书+源代码

    《COM本质论》是由美国著名软件专家Don Box撰写的一本深入探讨COM技术的经典著作,这本书对理解COM的核心概念、工作原理以及实际应用有着极高的价值。 COM的核心理念是“对象即组件”,它提供了一种标准的方式来...

    C#本质论(第3版)

    《C#本质论(第3版)》是一本深入探讨C# 4.0编程语言的书籍,它全面而细致地介绍了C#的各个方面,从基础语法到面向对象的高级特性,再到编程的最佳实践。本书不仅适合初学者学习C#语言的基础,也对经验丰富的开发者...

    C_#4.0本质论

    《C# 4.0本质论》是一本经典的C#入门教材,由Mark Michaelis撰写。...总的来说,《C# 4.0本质论》是一本全面介绍C#编程语言的书籍,对于希望学习和掌握C#编程的读者来说,是一本不可多得的参考教材。

    C#本质论源代码

    《C#本质论》是一本深入探讨C#编程语言核心概念和技术的著作,其源代码提供了丰富的实践示例,帮助读者更好地理解C#语言的精髓。这个压缩包包含的源代码对应于书籍的第三版,这意味着它涵盖了C#语言发展到一定阶段时...

    asp.net 本质论

    《ASP.NET本质论》这本书深入剖析了ASP.NET技术的核心概念,而非从编程语言的基础或数据库设计等常见话题入手。它关注的是ASP.NET如何与HTTP协议交互以及事件处理机制在其中的作用,这对于理解ASP.NET框架的工作原理...

    COM 本质论 源码

    通过研究《COM本质论》的源码,开发者可以深入理解COM组件的创建、查询、生命周期管理和多线程交互等核心概念,这对于Windows平台上的系统级编程和大型软件开发具有重要意义。此外,掌握COM也有助于理解后续的...

    COM本质论附带源码

    COM(Component Object ...通过阅读《COM本质论》并结合这些源码,读者将能够深入理解COM的内在机制,提升在Windows平台上进行组件化编程的能力。这些源码示例可以帮助读者实践COM编程,从而更好地消化书中的理论知识。

Global site tag (gtag.js) - Google Analytics