动态语言小结

    我在大一时做C大程时就有个想法:即游戏程序员应该把主要时间花在游戏的逻辑上,而不是与之不相关的代码上。编译器应该提供更好的出错检查。在我看来,花几个小时,就是为了找一个数组下标越界的错误,实在是很不值得。我用C写“俄罗斯方块”游戏,花了一星期,1000多行。我相信,一定有一种语言,可以花100行实现相同的功能,并且自动告诉我数组下标错误。

    动态语言的灵感:
        C++C相比,无疑更加灵活。尤其是它的多态特性,与C相比,减少了代码量,提高了可维护性。多态的特点:对象类型在运行时刻才确定。


    void f(Shape *s)
    
{
        s
->draw();
    }
    
    Shape 
*s=new Circle;
    f(s);


    当然,C++是用虚函数表这种巧妙的方法,化动态为静态。C++仍然是静态语言。

    但是,为什么不直接点呢?代码直接解释执行,在运行时刻判断。声明就变成多余了。因为你不知道它的真正类型,如void f(Shape *s)

    void f(s)
    
{
        s.draw();
    }
    
    s
=new Circle;
    f(s);

    在运行时,解释器知道s的类型是Cirle,在f()中就自然执行对应的函数了。所以,在动态语言中实现OO应该是很自然的事。

    后来我才知道,的确存在这样的语言,他们有许多共同的特点:

1.变量类型在运行时才确定

2.用很少的代码量就可以写很漂亮的程序。

3.类库很丰富。

4.可移植性很好。

5.大部分都面向对象。

    其实,有些事情只有动态语言才能做,有些事情动态语言做起来更简洁。比如反射,比如要求在运行时改变对象的属性,增加对象的方法等等等。

    比如,要实现以下功能:

     Dim  l  As   Object   =   New  ArrayList()
    l.(
" Add " )( 12 )
    l.(
" RemoveAt " )( 0 )
    把方法也看成一个参数。这在静态语言里是很难做到的,在动态语言里却很容易就能做到。

    不过,一旦解释执行,效率的确是个问题。动态语言为人类设计,程序员很容易读,电脑却不容易看懂。所以要先把动态语言转化成字节码,便于虚拟机阅读。然后再执行。

    动态语言不便于调试?由于类型在运行时刻才确定,所以声明就多余了。自然,编译错误就只能在运行时刻发现了。希望解释器功能越来越强大,能够轻松自动找出bug。但是既然是解释执行,动态语言要实现调试并不难。例如,在bash中,加参数-x就可以打印执行到的语句。Java可以调试。此外,调试只适用于小程序,对大型程序,启用日志是个好办法。

    与调试相对,动态语言在检查运行时错误时比静态语言更有优势。因为它们在运行时能够获得更多信息,因此解释器更容易找出错误。仅仅因为没有变量声明而认为动态语言开发效率低是错误的,事实上,总体而言,后者开发效率更高。

    当然,说这么多没用,不如自己动手实践一把。

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本节课的实验内容主要分为三个板块:HTML,CSS,JavaScript,其中,我对HTML技术的应用得到了熟练运用,并对其他动态网页设计方法进行了大致的了解。HTML是Hypertext Markup Language的英文缩写,即超文本标记语言。它是一种标记语言而非编程语言,由浏览器解释支持。HTML文件是一种文本文件,可以用记事本打开,当然也可以用其他开发工具,比如dream-weaver和VS等等。通过在文本中添加各种标签来告诉浏览器网页要显示的内容,以及以何种表现形式显示。浏览器按照自上而下的顺序解读HTML文件,同时浏览器并不会因为HTML代码出现错误而停止解读。在课上操作上机的时候,老师教会了我们怎么用最简单的TXT文件来设计自己想要设计的网页,并加入了多种元素。CSS是一种用来表现HTML文件样式的计算机语言。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。 而且CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。JavaScript是我认为我所学的技术里面最高端的一种技术。JavaScript是一种基于对象和事件驱动具有安全性能的脚本语言,使用JavaScript可以轻松的实现与HTML的互操作,并且完成丰富的页面交互效果,它是通过嵌入或调入在标准的HTML语言中实现的,它的出现弥补了HTML的缺陷,是java与HTML折衷的选择。学习本课的目的就是能够建立起自己设计出来的页面,经过几周的教学和自我实践摸索,我已经能创建专属于自己的HTML页面,超额完成自己的目标。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值