web开发之动态语言与静态语言

写服务器端程序(业务)的同学或多或少都接触不止一门编程语言,大体上分为编译型和解释型,直观感受上来讲,解释型往往注重语言本身的表达力,一方面减少代码量,另一方面提高代码的可读性。举个例子,ruby 有个著名的用于测试的库叫 rspec,示例代码:

class HelloWorld

   def say_hello 
      'Hello World!'
   end
   
end

describe HelloWorld do 
   context 'When testing the HelloWorld class' do 
      
      it "should say 'Hello World' when we call the say_hello method" do 
         hw = HelloWorld.new 
         message = hw.say_hello 
         expect(message).to eq "Hello World!"
      end
      
   end
end

我们可以看到 describe, context, it, expect, to, eq 作为方法名,在语言层面的支持(ruby支持方法调用不加括号)下,将代码的可读性大大提高,单看这句 expect(message).to eq "Hello World!",就是不懂程序的人,也能猜到它想要表达是:期望 message"Hello World!"。再来看看Go语言版本的测试库,示例如下:

var _ = Describe("Book", func() {
    var (
        longBook  Book
        shortBook Book
    )

    BeforeEach(func() {
        longBook = Book{
            Title:  "Les Miserables",
            Author: "Victor Hugo",
            Pages:  1488,
        }

        shortBook = Book{
            Title:  "Fox In Socks",
            Author: "Dr. Seuss",
            Pages:  24,
        }
    })

    Describe("Categorizing book length", func() {
        Context("With more than 300 pages", func() {
            It("should be a novel", func() {
                Expect(longBook.CategoryByLength()).To(Equal("NOVEL"))
            })
        })

        Context("With fewer than 300 pages", func() {
            It("should be a short story", func() {
                Expect(shortBook.CategoryByLength()).To(Equal("SHORT STORY"))
            })
        })
    })
})

对比明显,由于Go语言本身的表现力不足(当然也叫极简),比 rspec 的版本多了很多括号和 func 关键字,虽然仔细看其实差不都,但可读性真是不在一个数量级上。

说完表现力,我们再来谈谈性能。解释型语言绝大部分情况下在性能方面要落后编译型语言很多,当然这么比本身太过钻牛角尖,解释性语言由于设计之初就是要方便程序员表达大脑中的逻辑,同时提供语言运行时的便捷API,有得必有失,必然要舍弃一部分性能。而编译型语言由于对编译速度和硬件掌控度有更高的要求,所以需要舍弃很多语法糖,甚至还要提供更靠近硬件的接口以方便程序做针对性性能优化。

看来,“世界上本来就没有完美的事情” 这道理也适用在这里。那么我们该如何选择呢?这就是一个平衡的问题(假设对不同语言的熟悉程度相同):

  1. 需要快速迭代的新项目可以选择解释性语言,一方面代码量少,另一方面相关的框架(PHP/Laravel Ruby/Rails Python/Django)在项目前期可以帮我们省很多时间。

  2. 对于已经梳理清晰业务的新项目,在时间比较宽裕条件下,那我们完全可以用编译型语言,虽然写起来更繁琐一些,但是项目复杂到一定程度,你会发现代码的可读性与代码的魔法程度成反比,换句话说多少代码是要猜的。

  3. 如果业务有比较多的计算,无疑用编译型语言做针对性优化更为合适。

  4. 如果业务变化非常频繁或者业务逻辑本身就是不断变化的,那么用编译型语言就会显得比较笨拙,而且你会发现你的时间都用在编译上了。时间充裕的话完全可以做一个简单的DSL,rspec 就是个很好的例子。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容