动态语言和静态语言比较

动态语言和静态语言 有三个名词容易混淆:

1.

2.

3. Dynamic Programming Language (动态语言或动态编程语言) Dynamically Typed Language (动态类型语言) Statically Typed Language (静态类型语言)

FantasySoft 在他文章中所提到的动态语言与静态语言实际上指的就是动态类型语言与静态类型语言。 动态语言,准确地说,是指程序在运行时可以改变其结构:新的函数可以被引进,已有的函数可以被删除等在结构上的变化。比如众所周知的ECMAScript(JavaScript)便是一个动态语言。除此之外如Ruby

、Python 等也都属于动态语言,而C 、C++等语言则不属于动态语言。

所谓的动态类型语言,意思就是类型的检查是在运行时做的,比如如下代码是不是合法的要到运行时才判断(注意是运行时的类型判断):

defsum(a,b):

return a+b

而静态类型语言的类型判断是在运行前判断(如编译阶段),比如C#就是一个静态类型语言,静态类型语言为了达到多态会采取一些类型鉴别手段,如继承、接口,而动态类型语言却不需要,所以一般动态语言都会采用dynamic typing,常出现于脚本语言中。(idior 不知道这能不能回答你对动态语言多态的疑问^_^)

这里我需要明确说明一点,那就是,是不是动态类型语言与这门语言是不是类型安全的完全不相干的,不要将它们联系在一起!

静态类型语言的主要优点在于其结构非常规范,便于调试,方便类型安全;缺点是为此需要写更多的类型相关代码,导致不便于阅读、不清晰明了。动态类型语言的优点在于方便阅读,不需要写非常多的类型相关的代码;缺点自然就是不方便调试,命名不规范时会造成读不懂,不利于理解等。顺便说一下,现在有这样一种趋势,那就是合并动态类型与静态类型在一种语言中,这样可以在必要的时候取长补短,Boo 就是一个很好的试验性例子。^_^

最后说一下Boo ,Boo 是一个静态类型语言,虽然用duck typing可以模拟dynamic typing,但是duck 并不支持所有类型的操作替代,所以即使完全使用duck typing也不能达到dynamic typing。就像FantasySoft 所述,Type Inference不是动态类型语言的特性,所以支持Type Inference不代表这门语言就是dynamically typed。

再特地为Ninputer 这个VB 的fans 说一下VB.NET^_^,VB.NET 是dynamically typed语言。

1. 动态语言DynamicallyTypedLanguage

例如:ECMAScript(JavaScript)、Ruby 、Python 、VBScript 、php

也叫动态类型定义语言

与静态类型定义相反,一种在执行期间才去发现数据类型的语言, 动态语言是指程序在运行时可以改变其结构:新的函数可以被引进,已有的函数可以被删除等在结构上的变化。

动态语言的类型检查是在运行时做的。

它的优点是方便阅读,不需要写非常多的类型相关的代码; 缺点是不方便调试,命名不规范时会造成读不懂,不利于理解等。 目前java 平台下的动态语言有Groovy 、nice 、BeanShell 、Jython 、JRuby 、Rhino(JavaScript)、Jacl(TCL)、Bistro(SmallTalk)、Kawa(Lisp/Schema),真是越来越多了。java 下这么多的动态语言建议选择Groovy ,感觉血统较为正宗,兼容Java 的语法,java 程序员学习起来较为容易,上手较快。

2. 静态语言StaticallyTypedLanguage

例如:C 、C++、Java

也叫静态类型定义语言。即一种在编译时,数据类型是固定的语言。大多数静态类型定义语言强制这一点,它要求你在使用所有变量之前要声明它们的数据类型。

在使用数据之前,我们必须首先定义数据类型,这些数据类型包括int ,float,double等等。就相当于在使用它们之前,首先要为它们分配好内存空间。

静态类型语言的主要优点在于其结构非常规范,便于调试,方便

类型安全;

缺点是为此需要写更多的类型相关代码,导致不便于阅读、不清晰明了。

3. 强类型定义语言

一种总是强制类型定义的语言。Java 和Python 是强制类型定义的。如果你有一个整数,如果不显示地进行转换,你不能将其视为一个字符串

4. 弱类型定义语言

一种类型可以被忽略的语言,与强类型定义相反。VBScript 是弱类型定义的。在VBScript 中,可以将字符串 '12' 和整数 3 进行连接得到字符串'123' ,然后可以把它看成整数 123,而不需要显示转换。

5. 脚本语言

脚本语言代表一套与系统程序设计语言不同的协定。

它们牺牲执行速度和与系统程序设计语言相关的类型长度而提供更高的编程创作力和软件重用。

脚本语言更适合在联系复杂的应用程序中进行胶着。

为了简化连接组件的工作, 脚本语言被设计为无类型的,脚本语言一般是面向字符的,因为字符为许多不同的事物提供了一致的描述。

事实上,脚本语言都是动态语言,而动态语言都是解释型语言,不管它们是不是面向对象。

静态语言的优势到底在哪?

来自robbin 摘自 http://www.javaeye.com/article/33971?page=7 引用是像Java 或者C #这样强类型的准静态语言在实现复杂的业务逻辑、开发大型商业系统、以及那些生命周期很长的应用中也有着非常强的优势

这是一个存在于大家心里常识了。我承认我自己在潜意识里面也觉得静态强类型语言适合开发复杂,大型系统。而弱类型脚本语言不适合开发太复杂,太大型的项目。但是在参与这个讨论过程中,我突然开始置疑这个观点,事实究竟是不是这样的呢?

先定义一下标准:

强类型语言(静态类型语言) 是指需要进行变量/对象类型声明的语言,一般情况下需要编译执行。例如C/C++/Java/C#

弱类型语言(动态类型语言) 是指不需要进行变量/对象类型声明的语言,一般情况下不需要编译(但也有编译型的) 。例如PHP/ASP/Ruby/Python/Perl/ABAP/SQL/JavaScript/Unix Shell等等。 引用观点一:

静态类型语言因为类型强制声明,所以IDE 可以做到很好的代码感知能力,因为有IDE 的撑腰,所以开发大型系统,复杂系统比较有保障。

对于像Java 来说,IDEA/Eclipse确实在代码感知能力上面已经非

常强了,这无疑能够增加对大型系统复杂系统的掌控能力。但是除了Java 拥有这么强的IDE 武器之外,似乎其他语言从来没有这么强的IDE 。C#的Visual Studio 在GUI 开发方面和Wizard 方面很强,但是代码感知能力上和Eclipse 差的不是一点半点。至于Visual C++根本就是一个编译器而已,羞于提及Visual 这个字眼。更不要说那么多C/C++开发人员都是操起vi 吭哧吭哧写了几十万行代码呢。特别是像Linux Kernel 这种几百万行代码,也就是用vi 写出来的阿,够复杂,够大型,够长生命周期的吧。

引用观点二:

静态语言相对比较封闭的特点,使得第三方开发包对代码的侵害性可以降到很低。动态语言在这点上表现的就比较差,我想大家都有过从网上下载某个JS 包,然后放到项目代码里发生冲突的经历

也就是说静态类型语言可以保障package 的命名空间分割,从而避免命名冲突,代码的良好隔离性。但是这个观点也缺乏说服力。

静态类型语言中C,VB 都缺乏良好的命名空间分割,容易产生冲突,但是并没有影响他们做出来的系统就不够大,不够复杂。

而Visual C++开发的DLL 版本冲突也是臭名昭著的,似乎C++的命名空间没有给它带来很大的帮助。

而动态类型语言中Ruby/Python/Perl都有比较好的命名空间,特别是Python 和Perl ,例如CPAN 上面的第三方库成吨成吨的,也从来没有听说什么冲突的问题。

诚然像PHP ,JavaScript 这样缺乏命名空间的动态语言很容易出现问题,但是这似乎是因为他们缺乏OO 机制导致的,而不是因为他们动态类型导致的吧?

说到大型系统,复杂业务逻辑系统,Google 公司很多东西都是用python 开发的,这也证明了动态类型语言并非不能做大型的复杂的系统。其实我个人认为:

动态类型语言,特别是高级动态类型语言,反而能够让人们不需要分心去考虑程序编程问题,而集中精力思考业务逻辑实现,即思考过程即实现过程,用DSL 描述问题的过程就是编程的过程,这方面像Unix Shell,ruby ,SQL ,甚至PHP 都是相应领域当之无愧的DSL 语言。而显然静态类型语言基本都不满足这个要求。

那静态类型语言的优势究竟是什么呢?我认为就是执行效率非常高。所以但凡需要关注执行性能的地方就得用静态类型语言。其他方面似乎没有什么特别的优势。

若干评论:

1、看看yahoo 吧,它是用PHP 写的。给你用JA V A 也可能做不出来那样的性能。

2、我的一点感觉,动态语言足够灵活,因此虽然它能够让人更集中精力思考业务逻辑的实现,同时也向人工智能的方向走得更近一些,但因此它也更依赖于开发人员本身的技术功底,初学者、中级开发者,难以很好的利用它。而静态类型语言,与我们计算机教学的基本科目(c/pascal/basic)延续性比较好,所以对于刚毕业的学生而言,

更好接受和学习。因此我觉得还是学习/培训/开发成本占主要因素。一个不太恰当的例子:javascript 的正则表达式,虽然功能强大,但并不易理解和学习。一般只能copy/paste来用。所以很多情况下,还是宁愿手写标准js 来处理。

3、我感觉类似Java 这样的强类型的准静态语言还有一个重要的特点。一旦程序员基本掌握了语法规则和书写规范,写出来的程序的可读性会强很多,因为它本身的限制更多。在一个大型系统中,Team 成员之间互相可以知道对方在写什么是非常关键的,这也成为了交流的重要基础。

然而Ruby 这样的语言,虽然看上去更加符合“描述问题即解决问题”,但是对于同一段逻辑,同样可以满足要求,写法上却差别很大。我曾经见过用1行写出来的解决数读算法的Ruby 解法,谁能看懂?

4、我更经常见到的是Java 程序员屁大点事写几百行,Ruby 几行就搞定了

5、静态类型语言是指在编译时变量的数据类型即可确定的语言,多数静态类型语言要求在使用变量之前必须声明数据类型,某些具有类型推导能力的现代语言可能能够部分减轻这个要求.

动态类型语言是在运行时确定数据类型的语言。变量使用之前不需要类型声明,通常变量的类型是被赋值的那个值的类型。

强类型语言是一旦变量的类型被确定,就不能转化的语言。实际上所谓的貌似转化,都是通过中间变量来达到,原本的变量的类型肯

定是没有变化的。

弱类型语言则反之,一个变量的类型是由其应用上下文确定的。比如语言直接支持字符串和整数可以直接用 + 号搞定。当然,在支持运算符重载的强类型语言中也能通过外部实现的方式在形式上做到这一点,不过这个是完全不一样的内涵

通常的说,java/python都算是强类型的,而VB/Perl/C都是弱类型的.

不过相比于动态/静态语言的分类,强类型/弱类型更多的是一个相对的概念。

6、如果采用动态语言,单元测试上的工作量要比静态语言的多很多

robbin 回这一条。其实你忽略了一点,当使用类似RoR 这样的框架的时候,应用代码量是很少的,所以相应需要测试的部分也很少,比使用静态类型语言需要测试的部分少了很多。

另外,缺少单元测试没有你说的那么恐怖。我们现在就没有写单元测试,ruby 代码都已经有6000多行了,编程也好,排错也好,一样很轻松,哪有你吹的那么恐怖。

7、商业系统的复杂在于组织上交流的困难,一个大公司,内部有个人能把商业流程搞得一清二楚就不错了,这个人还能把过程给软件人员讲清楚那简直是可遇不可求的事。这样用ruby 反而有优势了,可以快速开发,促进交流,开发出个模型出来给商务人员看看,用用,自然交流起来就容易多了。

现在一个开发人员的开发效率比以前高多了,主要原因是因为开发语言和编译器的进步,这个趋势,只会继续下去,不要抱着过去的教条不放,java 也是在不断改进的,加了reflection, 加了assert ,加了泛型,下个版本,也要加脚本支持了。

8、其实静态类型语言,除了性能方面的考量之外,最大的优势就是可以提供静态类型安全,编译器可以检查你的每一个函数调用是不是书写了正确的名字,是不是提供了正确类型的参数。这样一个系统,配合自定义类型的功能,可以让很多错误(比许多人想象的要多)在编译时就能被发现和定位。

9、我在slashdot 上类似话题的讨论上曾经看到过有人抱怨动态语言,那个哥们是从事银行系统的,大概有10万行的python 代码,最后因为细小隐错不断而觉得无法维护,貌似要转到java 平台。(如果把slashdot 上近两年来关于ruby 和python 的帖子和评论看一边, 大概还能够找到这个跟贴)

从这哥们的描述来看,他的主要问题是没有单元测试或者单元测试没有达到语句覆盖或者更强的弱条件组合覆盖,从而导致某些非正常流程发生时,流经这些未被测试的语句导致语法错误而最终整个程序都挂掉. 对于业务系统来说,这是非常严重的事情。就像我前面说的那样,我自己的程序就曾经不止一次死在logging 语句上,因为最初我也不测试这类语句的可通过性。

至于单元测试有没有用,三五人的项目几千行的代码是看不出来的。其实,作坊式开发照样能够做出很多东西来,5年前国内的开发

方式基本上是没有单元测试的,照样也能玩得转。

但是,就我自己的体验而言,虽然我并不遵循TDD ,但单元测试是足够详尽的,而这个测试网给我的置信度(尤其是在修改代码和较大规模重构时) 是之前不可想象的。我估计上千行的程序,就能够在渐增式的单元测试中尝到好处。

10、编译器对程序员的帮助到底有多大,这个还是要应人而异的。编译器能查出来的很多都属于打字错误,拼写错误。对于robbin 来说,即使没有编译器,检查这种错误也是小菜一碟。可是对于经验不是很丰富的程序员来说,情况恐怕就大大不同了。毕竟程序员经验方面差异的一个重要方面就是Debug 能力和经验的差异。对高手来说仔细读上两遍程序就能发现的错误,对一些新手来说可能会花上一两小时,这种情况我在实际项目中碰到很多次了。

动态语言会导致开发质量下降吗? 离开CPUG 以后,我的邮箱清静了很多,果断退掉一些现在已经不太关注的邮件组后,只有haskell-cafe 和python 社区的邮件还比较热闹。不过这几天几位朋友都在问我这个事儿: https://groups.google.com/forum/#!topic/python-cn/yT3FvzgFLAs/discussion

codebase 中 merge 了别人的代码以后。即便双方都没有改动同一个文件,也可能出现这种情况:

A 只改动了 a.py 的一个方法的传参个数。

B 改动了 b.py, 并且 b.py 中调用了 a.py 中的那个方法改动前的版本。

merge 了两个文件以后, 程序员基本都不会意识到现在出了问题。

原因有两个:

1. python 程序员基本不用什么IDE, 如果使用 pydev 之类, 大致还能依靠 IDE 在merge 以后看到这个错。

2. python 没有编译的概念,没有机会看到编译器对这个语法问题的报错。

好了,现在只有等上线以后,通过某个事件触发这个bug 了。 请问各位是杂么防范这种问题的?

unit test ?

如果问我的意见,其实我的意见很简单的,这位楼主自己也很清楚。

是的,测试,测试再测试,计算机不变魔法。

我做过python -C #,python -Java 的不同项目对接,为此同时在一个项目里用不同的语言开发过近乎对等的功能,Python 比C#/Java节省一个数量级的开发量这个真的不是吹牛。

那么,你用十分之一的工作量完成了功能开发,再用十分之一的时间写对应的test 代码可不可以?

就算你在自己的代码里用doctest 完成了自测,项目组用unit test和其它测试脚本完成单元测试和框架级的测试,信不信你的开发量还是比java/C#要少?相对来说,你获得了更可靠的保证,这个保证是来自开发人员明确的代码定义,而非IDE 基于IDE 开发者思路的通用校检,哪一个更严格更可靠?如果你定制的质量检测脚本居然不能达到通用功能的程度,是不是应该检讨一下自己,多学习学习?

具体到这位朋友的问题,我们可以发现这样几处值得讨论的地方: 项目API 变更造成merge 时的冲突

这暴露了此项目缺少集成测试,无论你使用任何语言和技术,集成测试都非常重要。搭建一个友好、“正直”的集成测试环境,非常重要。这种事情不应该指望某一个人的IDE ,哪怕是每一个人的。因为在团队协作中,每一个人的代码都可能不是最终发布的代码。

应该把提交和上线当做一件严肃的事,上线之前一定要集成测试,类似API 变更冲突这种错误大多是可以避免的。

指望IDE 驱动编译器发现错误 另一方面,每个人提交完以后,应该再update 一次,然后在本地集成测试一次。这里IDE 有支持的话应该积极使用,虽然不能完全避免错误,但是有做比没做好。

同时我们也应该知道,这个功能用IDE 能完成,用脚本也一样可以,而且不会更麻烦。我在开发 socrates 项目时就是这样做的。事实上因为在python 中写测试更简单,我用起来感觉要比在C#/CPP中爽很多。

所以这个问题不在于用不用IDE ,而在于你有没有心去做这样的事。还是那句话,用python/ruby什么的,就算你加上写测试,还是省力的。

对动态语言的类型转换错误太过敏感 当然,我们应该承认,动态类型语言不检查传递的参数,确实会引发一些风险,但是在我接触过的项目中,真正要面对的总是资源管理问题和逻辑错误,不论哪一种语言哪一种应用,类型错误少之又少。一个数量级以上的性能提升,付出这样的代价相当值得。

静态语言现在也倾向于尽可能由编译器发现类型,越来越少的要求用户显式给出约束。包括类型系统最为严苛的haskell ,它也鼓励用户编写出编译器可以自动感知类型的代码。如果想兼顾书写的便利和静态类型语言的安全感,Java 程序员其实可以试试scala ,最近我也在学习这个语言,是个非常有爱的好东西。

无论用哪一种语言,最终写代码的仍然是人。具体到这个贴子中出现的问题,我认为首先要检讨团队管理过程,语言的问题只是个表像。无论动态语言还是静态语言,积极建立测试体系才是正道,无论用Java 还是Python ,CPP 还是ruby 。尤其在线系统,要有一个集成测试的环境。传统的静态类型语言可以避免此类小概率错误的一部分发生可能,而运用动态语言或现代的,更为智能的静态语言,则可以将更多的时间省下来,建立完整的质量管理体系,在更高的层面上消灭这种错,在应用项目开发中,后者胜出。

动态语言会淘汰静态语言吗? 上一篇博客动态语言会导致开发质量下降吗?,尽管没有我想像的那么多争议,但还是如期引发了一些误解。有一些朋友指出动态语言,具体来说是 Python 中的各种问题。这些我认为是大部分是正确的。

我写上文的用意,在于讨论动态语言使用过程中,关于质量控制的必要性,以及其引发的性价比方面的争议。这并不表示动态语言全面的优于静态语言,更不表示静态语言会被动态语言全面的取代。进一步,这里我简单的说一下,我所认识到的,静态语言相对的优越性,和存在意义。

这里首先我表达一下我一贯的观点:计算机不会魔法。具体来说两方面,一是离机器越近,性能上越有可能达到更快;二是目前的机器模型,总是以线性方式管理数据的(值得吐槽的是在操作系统以上,文件分区系统也总是这样干的,更底层能否以哪怕是极座标方式,直接在二/三维空间上定位访问,而非扇区、柱面、簇这种形式,我不清楚,有待方家指点)。

线性管理信息带来的效应就是:基于线性数据结构,或以地址访问信息的编程工具,通常来说会比基于字典结构的更快,至少有更大的优化空间。而静态语言的话,编译时我们已经确定了对象的结构和尺寸(动态尺寸的内容可以通过引用管理),这是动态语言无法做到的。动态语言的对象结构,总是基于字典结构,要兼顾对象结构在运

行时发生改变的问题。这使得它的数据管理总是要比直接地址访问要多上那么一层。这也是甚少见到动态语言编译器的原因。流行的动态语言,几乎都是解释/字节码平台,甚至,最常见的 Python/Ruby 等等语言,几乎都有饱受批评的 GIL (Global Interpreter Lock)。以 Python 社区的经验来说,多年来出现的数个无GIL 的 C-Python 实现,单核性能都不如现在的官方版本。Jython 和 IronPython 则是得益于 JVM 和 CLR ,这两个久经经考验的虚拟机平台,它们的 first-class language 都是静态编译型语言(尽管其主流编译器生成的是字节码,但是通常我们都视Java 和 C#为编译语言)。为 Perl 社区期待多年的 Perl6 ,至今还没有真正的发布(其虚拟机 Parrot 虽然已经发布,但受制于主力语言实现进度,现在还没有得到足够的实战验证)。为动态语言实现一个高性能的,特别是并行的高性能环境,难度之高,可见一斑。

根本上说,在当前的硬件模型上,想要以非线性的方式管理信息,动态伸缩,动态修改结构,非常的不容易。举一个例子,候捷老师有一个讲座,是以windows 95为例,詳細讲解 malloc/free 的底层实现,有听过的朋友应该对操作系统动态管理内存资源的复杂程度有所体会。类似的内容在很多操作系统之类的技术书籍中都有介绍,有兴趣的朋友可以找来看看,我手边有一本《Unix 系统编程》就有相关的内容。

这类问题涉及比较深入的底层问题,我不是科班出身,这方面比较外行,讲的不是很好,不过有兴趣的朋友可以深究一下,会发现这

事儿比看起来要麻烦得多。想要让动态语言达到静态化的性能,是件相当有挑战的事。Google 的 Protocol Buffer 协议,也是基于静态模型的。

现代的静态语言,搞了很好的“伪装”,使它写起来可以非常的有“动感”,例如 C#3,Scala 等,但究其本质,它们代码中涉及的类型,仍然是可以编译期确定的。我所接触过的语言中,此类功能最有历史的应该是Haskell ,而它是通过一个非常严苛的数学体系来推导类型,在此过程中,还是时有需要程序员显式声明函数类型,才能完成编译。

静态语言在变得越来越友好敏捷,动态语言在越来越快,但是两者之间的分界,仍然相当的清晰,静态语言更快,更具优化潜力。动态语言更灵活,更具表达能力。这是两者不能被互相取代的根本原因。

当然,性能问题并不简单,动态语言在宏观上往往没有具部的测试结果看起来那么慢,这是因为要表达复杂的业务逻辑,往往需要复杂的数据结构和访问代码,这些复杂的数据内容,要随着用户的访问不断变化。要实现这一切,如果使用静态语言,就要关注动态数据结构的实现,如果使用的是没有GC 的开发技术,还要关注内存资源的回收,确实会出现绕了一大圈儿,结果实现的系统还没有现成的动态语言快的现像(尽管这不是普遍的)。更何况现实中总是以线性读写的IO 接口,更严重拉平了不同语言之间的性能差异。所以现在比较得到认可的实现方式往往是以动态语言实现项目,然后,如果有需求,也有这个成本负担,就以静态语言优化性能瓶颈。

当然,上述的模式往往用在服务器型的项目中,在GUI 环境中,要与显示器、鼠标键盘等人机交互环境频繁的互动,这个资源付出非常的大,加上在CPP 等静态语言大行的时代,GUI 开发已经相当成熟,技术力量沉积的历史原因,这个领域仍然是以静态的、编译型的语言为主力。最多是为了提交二次开发能力,提供动态语言调用的接口,或嵌入一个解释环境,有限的利用。其实即使是服务器环境,随着互联网的发展,性能问题也正在越来越突出。我就遇到过某个简单逻辑的功能,使用Python 怎样都无法优化到理想的程度,最终用Objective C写了一个nginx 模块。另一方面说Objective C这样的语言已经相当的动态化,使用它的字典结构,要比用C 方便的多,在二进制上又可以完全兼容于C ,在性能和空间付出上,明显可以观察到比大多C 的字典结构,要多付出一些性能代价。计算机没有魔法,人得到便利,总是要付出一些计算资源。把它尽可能的贴近理想,是技术人员的目标。

越来越多的大型架构,要求我们不仅以模块、连接库和函数接口的层面思考问题,更多的要考虑实际运行时的,运行实例和服务器的行为。我们不但需要附件齐备的运行时环境,也需要可以直达硬件的,高速有效的工具。包括开发一些不那么动态但是更快速的定制服务环境,也成为一个越来越常见的需求。

虽然编程语言在发展,我们有更多,更强大的方式来表达我们的思维,但是随着用户量、商业模式和服务方式的迅速变化,新的挑战也不断出现。对于职业的IT 开发团队,我们在面对更多的挑战。我

们需要更为丰富的技术组合,指望一种技术一统天下,即使局限于互联网应用这个领域,也仍然是一个奢望。这十年来动态语言的兴起,其实是在补过去逻辑表达方面不足的功课,这是硬件发展带来的有限的福利,但是硬件资源永远是快速发展,但却不足使用。动态语言和静态语言组合使用,兼顾高效开发与高性能的效果,在目前可以预见的未来,仍然是比较实际的思路。

动态语言和静态语言 有三个名词容易混淆:

1.

2.

3. Dynamic Programming Language (动态语言或动态编程语言) Dynamically Typed Language (动态类型语言) Statically Typed Language (静态类型语言)

FantasySoft 在他文章中所提到的动态语言与静态语言实际上指的就是动态类型语言与静态类型语言。 动态语言,准确地说,是指程序在运行时可以改变其结构:新的函数可以被引进,已有的函数可以被删除等在结构上的变化。比如众所周知的ECMAScript(JavaScript)便是一个动态语言。除此之外如Ruby

、Python 等也都属于动态语言,而C 、C++等语言则不属于动态语言。

所谓的动态类型语言,意思就是类型的检查是在运行时做的,比如如下代码是不是合法的要到运行时才判断(注意是运行时的类型判断):

defsum(a,b):

return a+b

而静态类型语言的类型判断是在运行前判断(如编译阶段),比如C#就是一个静态类型语言,静态类型语言为了达到多态会采取一些类型鉴别手段,如继承、接口,而动态类型语言却不需要,所以一般动态语言都会采用dynamic typing,常出现于脚本语言中。(idior 不知道这能不能回答你对动态语言多态的疑问^_^)

这里我需要明确说明一点,那就是,是不是动态类型语言与这门语言是不是类型安全的完全不相干的,不要将它们联系在一起!

静态类型语言的主要优点在于其结构非常规范,便于调试,方便类型安全;缺点是为此需要写更多的类型相关代码,导致不便于阅读、不清晰明了。动态类型语言的优点在于方便阅读,不需要写非常多的类型相关的代码;缺点自然就是不方便调试,命名不规范时会造成读不懂,不利于理解等。顺便说一下,现在有这样一种趋势,那就是合并动态类型与静态类型在一种语言中,这样可以在必要的时候取长补短,Boo 就是一个很好的试验性例子。^_^

最后说一下Boo ,Boo 是一个静态类型语言,虽然用duck typing可以模拟dynamic typing,但是duck 并不支持所有类型的操作替代,所以即使完全使用duck typing也不能达到dynamic typing。就像FantasySoft 所述,Type Inference不是动态类型语言的特性,所以支持Type Inference不代表这门语言就是dynamically typed。

再特地为Ninputer 这个VB 的fans 说一下VB.NET^_^,VB.NET 是dynamically typed语言。

1. 动态语言DynamicallyTypedLanguage

例如:ECMAScript(JavaScript)、Ruby 、Python 、VBScript 、php

也叫动态类型定义语言

与静态类型定义相反,一种在执行期间才去发现数据类型的语言, 动态语言是指程序在运行时可以改变其结构:新的函数可以被引进,已有的函数可以被删除等在结构上的变化。

动态语言的类型检查是在运行时做的。

它的优点是方便阅读,不需要写非常多的类型相关的代码; 缺点是不方便调试,命名不规范时会造成读不懂,不利于理解等。 目前java 平台下的动态语言有Groovy 、nice 、BeanShell 、Jython 、JRuby 、Rhino(JavaScript)、Jacl(TCL)、Bistro(SmallTalk)、Kawa(Lisp/Schema),真是越来越多了。java 下这么多的动态语言建议选择Groovy ,感觉血统较为正宗,兼容Java 的语法,java 程序员学习起来较为容易,上手较快。

2. 静态语言StaticallyTypedLanguage

例如:C 、C++、Java

也叫静态类型定义语言。即一种在编译时,数据类型是固定的语言。大多数静态类型定义语言强制这一点,它要求你在使用所有变量之前要声明它们的数据类型。

在使用数据之前,我们必须首先定义数据类型,这些数据类型包括int ,float,double等等。就相当于在使用它们之前,首先要为它们分配好内存空间。

静态类型语言的主要优点在于其结构非常规范,便于调试,方便

类型安全;

缺点是为此需要写更多的类型相关代码,导致不便于阅读、不清晰明了。

3. 强类型定义语言

一种总是强制类型定义的语言。Java 和Python 是强制类型定义的。如果你有一个整数,如果不显示地进行转换,你不能将其视为一个字符串

4. 弱类型定义语言

一种类型可以被忽略的语言,与强类型定义相反。VBScript 是弱类型定义的。在VBScript 中,可以将字符串 '12' 和整数 3 进行连接得到字符串'123' ,然后可以把它看成整数 123,而不需要显示转换。

5. 脚本语言

脚本语言代表一套与系统程序设计语言不同的协定。

它们牺牲执行速度和与系统程序设计语言相关的类型长度而提供更高的编程创作力和软件重用。

脚本语言更适合在联系复杂的应用程序中进行胶着。

为了简化连接组件的工作, 脚本语言被设计为无类型的,脚本语言一般是面向字符的,因为字符为许多不同的事物提供了一致的描述。

事实上,脚本语言都是动态语言,而动态语言都是解释型语言,不管它们是不是面向对象。

静态语言的优势到底在哪?

来自robbin 摘自 http://www.javaeye.com/article/33971?page=7 引用是像Java 或者C #这样强类型的准静态语言在实现复杂的业务逻辑、开发大型商业系统、以及那些生命周期很长的应用中也有着非常强的优势

这是一个存在于大家心里常识了。我承认我自己在潜意识里面也觉得静态强类型语言适合开发复杂,大型系统。而弱类型脚本语言不适合开发太复杂,太大型的项目。但是在参与这个讨论过程中,我突然开始置疑这个观点,事实究竟是不是这样的呢?

先定义一下标准:

强类型语言(静态类型语言) 是指需要进行变量/对象类型声明的语言,一般情况下需要编译执行。例如C/C++/Java/C#

弱类型语言(动态类型语言) 是指不需要进行变量/对象类型声明的语言,一般情况下不需要编译(但也有编译型的) 。例如PHP/ASP/Ruby/Python/Perl/ABAP/SQL/JavaScript/Unix Shell等等。 引用观点一:

静态类型语言因为类型强制声明,所以IDE 可以做到很好的代码感知能力,因为有IDE 的撑腰,所以开发大型系统,复杂系统比较有保障。

对于像Java 来说,IDEA/Eclipse确实在代码感知能力上面已经非

常强了,这无疑能够增加对大型系统复杂系统的掌控能力。但是除了Java 拥有这么强的IDE 武器之外,似乎其他语言从来没有这么强的IDE 。C#的Visual Studio 在GUI 开发方面和Wizard 方面很强,但是代码感知能力上和Eclipse 差的不是一点半点。至于Visual C++根本就是一个编译器而已,羞于提及Visual 这个字眼。更不要说那么多C/C++开发人员都是操起vi 吭哧吭哧写了几十万行代码呢。特别是像Linux Kernel 这种几百万行代码,也就是用vi 写出来的阿,够复杂,够大型,够长生命周期的吧。

引用观点二:

静态语言相对比较封闭的特点,使得第三方开发包对代码的侵害性可以降到很低。动态语言在这点上表现的就比较差,我想大家都有过从网上下载某个JS 包,然后放到项目代码里发生冲突的经历

也就是说静态类型语言可以保障package 的命名空间分割,从而避免命名冲突,代码的良好隔离性。但是这个观点也缺乏说服力。

静态类型语言中C,VB 都缺乏良好的命名空间分割,容易产生冲突,但是并没有影响他们做出来的系统就不够大,不够复杂。

而Visual C++开发的DLL 版本冲突也是臭名昭著的,似乎C++的命名空间没有给它带来很大的帮助。

而动态类型语言中Ruby/Python/Perl都有比较好的命名空间,特别是Python 和Perl ,例如CPAN 上面的第三方库成吨成吨的,也从来没有听说什么冲突的问题。

诚然像PHP ,JavaScript 这样缺乏命名空间的动态语言很容易出现问题,但是这似乎是因为他们缺乏OO 机制导致的,而不是因为他们动态类型导致的吧?

说到大型系统,复杂业务逻辑系统,Google 公司很多东西都是用python 开发的,这也证明了动态类型语言并非不能做大型的复杂的系统。其实我个人认为:

动态类型语言,特别是高级动态类型语言,反而能够让人们不需要分心去考虑程序编程问题,而集中精力思考业务逻辑实现,即思考过程即实现过程,用DSL 描述问题的过程就是编程的过程,这方面像Unix Shell,ruby ,SQL ,甚至PHP 都是相应领域当之无愧的DSL 语言。而显然静态类型语言基本都不满足这个要求。

那静态类型语言的优势究竟是什么呢?我认为就是执行效率非常高。所以但凡需要关注执行性能的地方就得用静态类型语言。其他方面似乎没有什么特别的优势。

若干评论:

1、看看yahoo 吧,它是用PHP 写的。给你用JA V A 也可能做不出来那样的性能。

2、我的一点感觉,动态语言足够灵活,因此虽然它能够让人更集中精力思考业务逻辑的实现,同时也向人工智能的方向走得更近一些,但因此它也更依赖于开发人员本身的技术功底,初学者、中级开发者,难以很好的利用它。而静态类型语言,与我们计算机教学的基本科目(c/pascal/basic)延续性比较好,所以对于刚毕业的学生而言,

更好接受和学习。因此我觉得还是学习/培训/开发成本占主要因素。一个不太恰当的例子:javascript 的正则表达式,虽然功能强大,但并不易理解和学习。一般只能copy/paste来用。所以很多情况下,还是宁愿手写标准js 来处理。

3、我感觉类似Java 这样的强类型的准静态语言还有一个重要的特点。一旦程序员基本掌握了语法规则和书写规范,写出来的程序的可读性会强很多,因为它本身的限制更多。在一个大型系统中,Team 成员之间互相可以知道对方在写什么是非常关键的,这也成为了交流的重要基础。

然而Ruby 这样的语言,虽然看上去更加符合“描述问题即解决问题”,但是对于同一段逻辑,同样可以满足要求,写法上却差别很大。我曾经见过用1行写出来的解决数读算法的Ruby 解法,谁能看懂?

4、我更经常见到的是Java 程序员屁大点事写几百行,Ruby 几行就搞定了

5、静态类型语言是指在编译时变量的数据类型即可确定的语言,多数静态类型语言要求在使用变量之前必须声明数据类型,某些具有类型推导能力的现代语言可能能够部分减轻这个要求.

动态类型语言是在运行时确定数据类型的语言。变量使用之前不需要类型声明,通常变量的类型是被赋值的那个值的类型。

强类型语言是一旦变量的类型被确定,就不能转化的语言。实际上所谓的貌似转化,都是通过中间变量来达到,原本的变量的类型肯

定是没有变化的。

弱类型语言则反之,一个变量的类型是由其应用上下文确定的。比如语言直接支持字符串和整数可以直接用 + 号搞定。当然,在支持运算符重载的强类型语言中也能通过外部实现的方式在形式上做到这一点,不过这个是完全不一样的内涵

通常的说,java/python都算是强类型的,而VB/Perl/C都是弱类型的.

不过相比于动态/静态语言的分类,强类型/弱类型更多的是一个相对的概念。

6、如果采用动态语言,单元测试上的工作量要比静态语言的多很多

robbin 回这一条。其实你忽略了一点,当使用类似RoR 这样的框架的时候,应用代码量是很少的,所以相应需要测试的部分也很少,比使用静态类型语言需要测试的部分少了很多。

另外,缺少单元测试没有你说的那么恐怖。我们现在就没有写单元测试,ruby 代码都已经有6000多行了,编程也好,排错也好,一样很轻松,哪有你吹的那么恐怖。

7、商业系统的复杂在于组织上交流的困难,一个大公司,内部有个人能把商业流程搞得一清二楚就不错了,这个人还能把过程给软件人员讲清楚那简直是可遇不可求的事。这样用ruby 反而有优势了,可以快速开发,促进交流,开发出个模型出来给商务人员看看,用用,自然交流起来就容易多了。

现在一个开发人员的开发效率比以前高多了,主要原因是因为开发语言和编译器的进步,这个趋势,只会继续下去,不要抱着过去的教条不放,java 也是在不断改进的,加了reflection, 加了assert ,加了泛型,下个版本,也要加脚本支持了。

8、其实静态类型语言,除了性能方面的考量之外,最大的优势就是可以提供静态类型安全,编译器可以检查你的每一个函数调用是不是书写了正确的名字,是不是提供了正确类型的参数。这样一个系统,配合自定义类型的功能,可以让很多错误(比许多人想象的要多)在编译时就能被发现和定位。

9、我在slashdot 上类似话题的讨论上曾经看到过有人抱怨动态语言,那个哥们是从事银行系统的,大概有10万行的python 代码,最后因为细小隐错不断而觉得无法维护,貌似要转到java 平台。(如果把slashdot 上近两年来关于ruby 和python 的帖子和评论看一边, 大概还能够找到这个跟贴)

从这哥们的描述来看,他的主要问题是没有单元测试或者单元测试没有达到语句覆盖或者更强的弱条件组合覆盖,从而导致某些非正常流程发生时,流经这些未被测试的语句导致语法错误而最终整个程序都挂掉. 对于业务系统来说,这是非常严重的事情。就像我前面说的那样,我自己的程序就曾经不止一次死在logging 语句上,因为最初我也不测试这类语句的可通过性。

至于单元测试有没有用,三五人的项目几千行的代码是看不出来的。其实,作坊式开发照样能够做出很多东西来,5年前国内的开发

方式基本上是没有单元测试的,照样也能玩得转。

但是,就我自己的体验而言,虽然我并不遵循TDD ,但单元测试是足够详尽的,而这个测试网给我的置信度(尤其是在修改代码和较大规模重构时) 是之前不可想象的。我估计上千行的程序,就能够在渐增式的单元测试中尝到好处。

10、编译器对程序员的帮助到底有多大,这个还是要应人而异的。编译器能查出来的很多都属于打字错误,拼写错误。对于robbin 来说,即使没有编译器,检查这种错误也是小菜一碟。可是对于经验不是很丰富的程序员来说,情况恐怕就大大不同了。毕竟程序员经验方面差异的一个重要方面就是Debug 能力和经验的差异。对高手来说仔细读上两遍程序就能发现的错误,对一些新手来说可能会花上一两小时,这种情况我在实际项目中碰到很多次了。

动态语言会导致开发质量下降吗? 离开CPUG 以后,我的邮箱清静了很多,果断退掉一些现在已经不太关注的邮件组后,只有haskell-cafe 和python 社区的邮件还比较热闹。不过这几天几位朋友都在问我这个事儿: https://groups.google.com/forum/#!topic/python-cn/yT3FvzgFLAs/discussion

codebase 中 merge 了别人的代码以后。即便双方都没有改动同一个文件,也可能出现这种情况:

A 只改动了 a.py 的一个方法的传参个数。

B 改动了 b.py, 并且 b.py 中调用了 a.py 中的那个方法改动前的版本。

merge 了两个文件以后, 程序员基本都不会意识到现在出了问题。

原因有两个:

1. python 程序员基本不用什么IDE, 如果使用 pydev 之类, 大致还能依靠 IDE 在merge 以后看到这个错。

2. python 没有编译的概念,没有机会看到编译器对这个语法问题的报错。

好了,现在只有等上线以后,通过某个事件触发这个bug 了。 请问各位是杂么防范这种问题的?

unit test ?

如果问我的意见,其实我的意见很简单的,这位楼主自己也很清楚。

是的,测试,测试再测试,计算机不变魔法。

我做过python -C #,python -Java 的不同项目对接,为此同时在一个项目里用不同的语言开发过近乎对等的功能,Python 比C#/Java节省一个数量级的开发量这个真的不是吹牛。

那么,你用十分之一的工作量完成了功能开发,再用十分之一的时间写对应的test 代码可不可以?

就算你在自己的代码里用doctest 完成了自测,项目组用unit test和其它测试脚本完成单元测试和框架级的测试,信不信你的开发量还是比java/C#要少?相对来说,你获得了更可靠的保证,这个保证是来自开发人员明确的代码定义,而非IDE 基于IDE 开发者思路的通用校检,哪一个更严格更可靠?如果你定制的质量检测脚本居然不能达到通用功能的程度,是不是应该检讨一下自己,多学习学习?

具体到这位朋友的问题,我们可以发现这样几处值得讨论的地方: 项目API 变更造成merge 时的冲突

这暴露了此项目缺少集成测试,无论你使用任何语言和技术,集成测试都非常重要。搭建一个友好、“正直”的集成测试环境,非常重要。这种事情不应该指望某一个人的IDE ,哪怕是每一个人的。因为在团队协作中,每一个人的代码都可能不是最终发布的代码。

应该把提交和上线当做一件严肃的事,上线之前一定要集成测试,类似API 变更冲突这种错误大多是可以避免的。

指望IDE 驱动编译器发现错误 另一方面,每个人提交完以后,应该再update 一次,然后在本地集成测试一次。这里IDE 有支持的话应该积极使用,虽然不能完全避免错误,但是有做比没做好。

同时我们也应该知道,这个功能用IDE 能完成,用脚本也一样可以,而且不会更麻烦。我在开发 socrates 项目时就是这样做的。事实上因为在python 中写测试更简单,我用起来感觉要比在C#/CPP中爽很多。

所以这个问题不在于用不用IDE ,而在于你有没有心去做这样的事。还是那句话,用python/ruby什么的,就算你加上写测试,还是省力的。

对动态语言的类型转换错误太过敏感 当然,我们应该承认,动态类型语言不检查传递的参数,确实会引发一些风险,但是在我接触过的项目中,真正要面对的总是资源管理问题和逻辑错误,不论哪一种语言哪一种应用,类型错误少之又少。一个数量级以上的性能提升,付出这样的代价相当值得。

静态语言现在也倾向于尽可能由编译器发现类型,越来越少的要求用户显式给出约束。包括类型系统最为严苛的haskell ,它也鼓励用户编写出编译器可以自动感知类型的代码。如果想兼顾书写的便利和静态类型语言的安全感,Java 程序员其实可以试试scala ,最近我也在学习这个语言,是个非常有爱的好东西。

无论用哪一种语言,最终写代码的仍然是人。具体到这个贴子中出现的问题,我认为首先要检讨团队管理过程,语言的问题只是个表像。无论动态语言还是静态语言,积极建立测试体系才是正道,无论用Java 还是Python ,CPP 还是ruby 。尤其在线系统,要有一个集成测试的环境。传统的静态类型语言可以避免此类小概率错误的一部分发生可能,而运用动态语言或现代的,更为智能的静态语言,则可以将更多的时间省下来,建立完整的质量管理体系,在更高的层面上消灭这种错,在应用项目开发中,后者胜出。

动态语言会淘汰静态语言吗? 上一篇博客动态语言会导致开发质量下降吗?,尽管没有我想像的那么多争议,但还是如期引发了一些误解。有一些朋友指出动态语言,具体来说是 Python 中的各种问题。这些我认为是大部分是正确的。

我写上文的用意,在于讨论动态语言使用过程中,关于质量控制的必要性,以及其引发的性价比方面的争议。这并不表示动态语言全面的优于静态语言,更不表示静态语言会被动态语言全面的取代。进一步,这里我简单的说一下,我所认识到的,静态语言相对的优越性,和存在意义。

这里首先我表达一下我一贯的观点:计算机不会魔法。具体来说两方面,一是离机器越近,性能上越有可能达到更快;二是目前的机器模型,总是以线性方式管理数据的(值得吐槽的是在操作系统以上,文件分区系统也总是这样干的,更底层能否以哪怕是极座标方式,直接在二/三维空间上定位访问,而非扇区、柱面、簇这种形式,我不清楚,有待方家指点)。

线性管理信息带来的效应就是:基于线性数据结构,或以地址访问信息的编程工具,通常来说会比基于字典结构的更快,至少有更大的优化空间。而静态语言的话,编译时我们已经确定了对象的结构和尺寸(动态尺寸的内容可以通过引用管理),这是动态语言无法做到的。动态语言的对象结构,总是基于字典结构,要兼顾对象结构在运

行时发生改变的问题。这使得它的数据管理总是要比直接地址访问要多上那么一层。这也是甚少见到动态语言编译器的原因。流行的动态语言,几乎都是解释/字节码平台,甚至,最常见的 Python/Ruby 等等语言,几乎都有饱受批评的 GIL (Global Interpreter Lock)。以 Python 社区的经验来说,多年来出现的数个无GIL 的 C-Python 实现,单核性能都不如现在的官方版本。Jython 和 IronPython 则是得益于 JVM 和 CLR ,这两个久经经考验的虚拟机平台,它们的 first-class language 都是静态编译型语言(尽管其主流编译器生成的是字节码,但是通常我们都视Java 和 C#为编译语言)。为 Perl 社区期待多年的 Perl6 ,至今还没有真正的发布(其虚拟机 Parrot 虽然已经发布,但受制于主力语言实现进度,现在还没有得到足够的实战验证)。为动态语言实现一个高性能的,特别是并行的高性能环境,难度之高,可见一斑。

根本上说,在当前的硬件模型上,想要以非线性的方式管理信息,动态伸缩,动态修改结构,非常的不容易。举一个例子,候捷老师有一个讲座,是以windows 95为例,詳細讲解 malloc/free 的底层实现,有听过的朋友应该对操作系统动态管理内存资源的复杂程度有所体会。类似的内容在很多操作系统之类的技术书籍中都有介绍,有兴趣的朋友可以找来看看,我手边有一本《Unix 系统编程》就有相关的内容。

这类问题涉及比较深入的底层问题,我不是科班出身,这方面比较外行,讲的不是很好,不过有兴趣的朋友可以深究一下,会发现这

事儿比看起来要麻烦得多。想要让动态语言达到静态化的性能,是件相当有挑战的事。Google 的 Protocol Buffer 协议,也是基于静态模型的。

现代的静态语言,搞了很好的“伪装”,使它写起来可以非常的有“动感”,例如 C#3,Scala 等,但究其本质,它们代码中涉及的类型,仍然是可以编译期确定的。我所接触过的语言中,此类功能最有历史的应该是Haskell ,而它是通过一个非常严苛的数学体系来推导类型,在此过程中,还是时有需要程序员显式声明函数类型,才能完成编译。

静态语言在变得越来越友好敏捷,动态语言在越来越快,但是两者之间的分界,仍然相当的清晰,静态语言更快,更具优化潜力。动态语言更灵活,更具表达能力。这是两者不能被互相取代的根本原因。

当然,性能问题并不简单,动态语言在宏观上往往没有具部的测试结果看起来那么慢,这是因为要表达复杂的业务逻辑,往往需要复杂的数据结构和访问代码,这些复杂的数据内容,要随着用户的访问不断变化。要实现这一切,如果使用静态语言,就要关注动态数据结构的实现,如果使用的是没有GC 的开发技术,还要关注内存资源的回收,确实会出现绕了一大圈儿,结果实现的系统还没有现成的动态语言快的现像(尽管这不是普遍的)。更何况现实中总是以线性读写的IO 接口,更严重拉平了不同语言之间的性能差异。所以现在比较得到认可的实现方式往往是以动态语言实现项目,然后,如果有需求,也有这个成本负担,就以静态语言优化性能瓶颈。

当然,上述的模式往往用在服务器型的项目中,在GUI 环境中,要与显示器、鼠标键盘等人机交互环境频繁的互动,这个资源付出非常的大,加上在CPP 等静态语言大行的时代,GUI 开发已经相当成熟,技术力量沉积的历史原因,这个领域仍然是以静态的、编译型的语言为主力。最多是为了提交二次开发能力,提供动态语言调用的接口,或嵌入一个解释环境,有限的利用。其实即使是服务器环境,随着互联网的发展,性能问题也正在越来越突出。我就遇到过某个简单逻辑的功能,使用Python 怎样都无法优化到理想的程度,最终用Objective C写了一个nginx 模块。另一方面说Objective C这样的语言已经相当的动态化,使用它的字典结构,要比用C 方便的多,在二进制上又可以完全兼容于C ,在性能和空间付出上,明显可以观察到比大多C 的字典结构,要多付出一些性能代价。计算机没有魔法,人得到便利,总是要付出一些计算资源。把它尽可能的贴近理想,是技术人员的目标。

越来越多的大型架构,要求我们不仅以模块、连接库和函数接口的层面思考问题,更多的要考虑实际运行时的,运行实例和服务器的行为。我们不但需要附件齐备的运行时环境,也需要可以直达硬件的,高速有效的工具。包括开发一些不那么动态但是更快速的定制服务环境,也成为一个越来越常见的需求。

虽然编程语言在发展,我们有更多,更强大的方式来表达我们的思维,但是随着用户量、商业模式和服务方式的迅速变化,新的挑战也不断出现。对于职业的IT 开发团队,我们在面对更多的挑战。我

们需要更为丰富的技术组合,指望一种技术一统天下,即使局限于互联网应用这个领域,也仍然是一个奢望。这十年来动态语言的兴起,其实是在补过去逻辑表达方面不足的功课,这是硬件发展带来的有限的福利,但是硬件资源永远是快速发展,但却不足使用。动态语言和静态语言组合使用,兼顾高效开发与高性能的效果,在目前可以预见的未来,仍然是比较实际的思路。


相关文章

  • 英语介词的动词性试探
  • 江西省南昌市紫阳大道99号 江西师范大学外国语学院 邮编330022 英语介词的动词性试探 摘要:英语被称为"介词的语言",现代英语介词虽然种类不多,但使用频繁.究其衍生和发展的过程,介词与动词关系密切.试从两类词性的兼 ...查看


  • 从世博标语翻译中的看中西方思维的不同
  • 从世博标语翻译中的看中西方思维的不同 时间:2011-04-22 11:45:02 作者:秩名 论文导读:胡维(2008)一般来讲,思维方式具有深远的民族文化根源.这里的翻译是不对等的.中西方文化差异-以上海世博会标语为例.原标语的潜在之意 ...查看


  • 网站建设基础知识
  • 学习网站制作基础知识 一. 基础 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 网站制作流程 相信很多朋友第一次接触到网 ...查看


  • 27 关于极限概念的_语言
  • 第8卷第3期 1999年 8月数学教育学报JOURNAL OF MA THEMA TICS EDUCA TION Vol. 8No. 3Aug. 1999 关于极限概念的ε-语言 姜 涛① 摘要 针对<关于极限概念的非ε-语言> ...查看


  • C语言编译全过程介绍
  • C 语言的编译链接过程要把我们编写的一个c 程序(源代码)转换成可以在硬件上运行的程序(可执行代码) ,需要进行编译和链接.编译就是把文本形式源代码翻译为机器语言形式的目标文件的过程.链接是把目标文件.操作系统的启动代码和用到的库文件进行组 ...查看


  • 网上自考书店的规划书
  • 网上自考书店的规划书 一. 网站的基本的建议性解决方案 (1) 域名:www.zikao.com (2) 邮箱地址:[email protected] (3) 技术选型:html语言,asp程序 ,flash技术等相关 技术的结合,还有站内查询 ...查看


  • 描写方法及其作用分析.说明文阅读.考试作文写作要点
  • 魏聪专用,不对外开放 描写方法及其作用分析 一.一般描写及其作用  外貌描写(肖像描写)  语言描写(对话描写.独白.对白.群白.旁白)    动作描写(行动描写)  人物描写 神态描写:表情.情绪.动作    ...查看


  • _依然_与_仍然_的比较分析_李树
  • 第25卷第5期Vol.25 NO.5 萍乡高等专科学校学报JournalofPingxiangCollege 2008年10月Oct.2008 "依然"与"仍然"的比较分析 李 树,任海波 (上海师范 ...查看


  • 基于角色访问控制的UML表示
  • Michael E. Shin.Gail-Joon Ahn著,UMLChina 译 摘要 在基于角色访问控制(role-based access control,RBAC)中,权限和角色相关,用户被当作相应角色的成员而获得角色的权限.RBA ...查看


热门内容