パスワードを忘れた? アカウント作成
14061 story

SBCL 1.0 Released! 57

ストーリー by kazekiri
括弧の逆襲 部門より

Anonymous Coward 曰く、

Steel Bank Common Lisp 1.0がリリースされました。 SBCLはCMU CLから分離したCommon Lisp処理系で、より多くのプラットフォームをサポート、ネイティブスレッドのサポート、Unicodeと主要なロケール(EUC-JP、Shift_JIS含む)をサポートなどの特徴があります。

Lispと言えば遅いという印象があるかもしれませんが、Computer Language Shootoutの結果ではトータルでJavaよりもパフォーマンスが高くなるなど、かなり高性能な処理系です。

この議論は賞味期限が切れたので、アーカイブ化されています。 新たにコメントを付けることはできません。
  • Lispと言えば遅い (スコア:2, すばらしい洞察)

    by Anonymous Coward on 2006年12月01日 17時39分 (#1068351)
    > Lispと言えば遅い
    いや、第一印象は「Lispと言えば括弧が多い」が多数派だと思うに100ガバス。

    # 論点が違うのは百も承知なのでAC
  • えーと (スコア:1, おもしろおかしい)

    by Anonymous Coward on 2006年12月01日 16時15分 (#1068305)
    > Javaよりもパフォーマンスが高くなるなど、かなり高性能な処理系です。

    笑うところですか?
    • by Anonymous Coward
      「がんばって褒め言葉ひねり出しました」感がありますねー
      じゃ大して速くないじゃんと小一時間(以下略)

      # 男は黙ってC++なのでAC
      • by Anonymous Coward
        平たく言うと「亀より速い」けど「牛より遅い」みたいな感じですか?
        • Re:えーと (スコア:1, おもしろおかしい)

          by Anonymous Coward on 2006年12月01日 22時34分 (#1068489)
          亀は意外と速く泳ぐ
          親コメント
          • by Anonymous Coward
            亀といえばxyzzyですね。
            個人的にEmacsよりコンパクトで好きです。

            xyzzy Lisp Programming
            http://www.geocities.jp/m_hiroi/xyzzy_lisp.html
        • by Anonymous Coward
          亀とも引き分けがいいとこなのに勝ったと言いきってる感じ
        • by Anonymous Coward
          イマドキのJavaは亀でもないと思うが。
    • by Anonymous Coward
      >Lispと言えば遅いという印象があるかもしれません
      笑いどころはこっちだろ。

      よくある「elispのアプリは遅い。Cで書き直せ」みたいな話を
      「Lispは遅い」と前提もなにもなく鵜呑みにした、その上で
      スクリプト言語の紹介でPerlでもPythonでもよく使われる
      「**な処理でベンチマークを取ったらJavaより速かった」的な記述をこれまた
      自家バイアスかまして解釈したんだと思われ。

      これまでのインタプリタ型言語の比較で、Lisp系のものが全般に
      他より遅いという話は聞かない。逆ならよく聞く。
      Javaな人が「この処理ではCより速かった」とか言って喜ぶように
      スクリプト言語の愛好者は「Javaより速かった」と宣伝する。
      そういう当り前の光景も、見る人が見ればここまで勘違いできる、好例だな。
      • by Anonymous Coward
        よくある「elispのアプリは遅い。Cで書き直せ」みたいな話を
        「Lispは遅い」と前提もなにもなく鵜呑みにした、その上で
        スクリプト言語の紹介でPerlでもPythonでもよく使われる
        「**な処理でベンチマークを取ったらJavaより速かった」的な記述をこれまた
        自家バイアスかまして解釈したんだと思われ。

        推測でよくそこまでわかりましたね。エスパーですか?
        • by Anonymous Coward
          アイロニャーだと思われ。
        • by Anonymous Coward
          推測も何も、まともに使ったこともなく話だけで事情通ヅラする奴の常套手段じゃん
  • by Anonymous Coward on 2006年12月01日 17時43分 (#1068354)
    下記のページの中ほどにLisp,Java,Python,Perl,C++のベンチマークの比較が並んでいます。

    Lisp プログラマのための Python 人門
    http://www.unixuser.org/~euske/doc/python/python-lisp-j.html

    そんなにバカにされるほど遅いのかな?
    • >下記のページの中ほどにLisp,Java,Python,Perl,C++のベンチマークの比較が並んでいます

      参考にならなくはないけど、2002年のデータじゃ、現実と乖離している感が否めない。
    • 特徴的に早い下記3つを見て。
      (C++を1としたもの)
      例外処理 0.01
      リスト処理 0.93
      単語を数える 0.73

      例外処理はすげぇと思うが、残りの2つずるくない?
      リスト処理や単語を数える時のパースの速度は事前処理って事じゃないの?

      ファイル中の数値を総計 7.54
      だよ?
  • 技術野郎の復讐---Revenge of the Nerds--- [practical-scheme.net]とかそこに引用されている
    comp.lang.lisp > How I lost my faith (very long) [google.com]を読むとLispってのは
    Nerds御用達言語らしいというのが想像できて、あこがれます。2つの記事を(超)要約すると
    「Lispを使えば短期間で開発ができて、コードの量も非常に小さくできる。PythonはLispの再発明だ」
    ということです。しかし、ヘタレなぼくにはそのすごさがいまいち理解できません。そこに書かれている
    (defun foo (n)
        #'(lambda (i) (incf n i)))
    はいったい何をしたいのでしょうか。Lisperの方、教えてください。

    Rubyとの関連についてはRe: Paul Graham essay on language popularity /// Ruby Lambda [nagaokaut.ac.jp]
    に書かれています。

    あと、Lispは方言が多すぎるということに近づきがたい印象を持ちます。今回またSBCLという
    Common Lispの1方言ができたのでしょうか。

    --
    love && peace && free_software
    t-nissie
    • Lispに方言が多かったのは、過去の話じゃないですか。いまはANSI Common Lisp標準がありますから。もちろん処理系によって細かい差異はあるんですけど、それはC言語なんかでも同じですよね?

      親コメント
      • by t-nissie (8647) on 2006年12月02日 7時20分 (#1068552) ホームページ 日記
        #1068425 [srad.jp]で引用されている
        WHY Common Lisp? [msi.co.jp]を読むとそうみたいですね。
        で、SchemeにはR5RSがあると。

        > In 技術野郎の復讐---Revenge of the Nerds---
        > * これが、他のLisp方言におけるアキュムレータジェネレータのコードだ。
        > Scheme: (define (foo n) (lambda (i) (set! n (+ n i)) n))
        > Goo: (df foo (n) (op incf n _)))
        > Arc: (def foo (n) [++ n _])
        Emacs は (defun foo (n) '(lambda (i) (incf n i))) でしょうか。

        各Lispの方言の中では標準が固まっているといってよいのでしょうか。

        しかし、各方言の特徴をWikipediaなんかで読んでも話が高度すぎて
        畏れ多いというか、わけがわからないというか…
        --
        love && peace && free_software
        t-nissie
        親コメント
        • Re:標準 (スコア:3, 興味深い)

          by kr (10950) on 2006年12月03日 2時04分 (#1068818) 日記
          Emacs は (defun foo (n) '(lambda (i) (incf n i))) でしょうか。

          念のため突っ込みを入れておくと、Emacs Lispにはclosureが無いので、これは意図通りに動きません。 例えば、元コメントの関数fooを定義した後で、以下を実行してみるとCommon Lispとの違いが分かります。

          (let ((n 42) (x (foo 1)))
            (print (funcall x 1))
            (print (funcall x 1))
            (print n))
          Common Lispでは2, 3, 42が順に表示されますが(1.0じゃないけどSBCL 0.9.16で確認)、 Emacs Lispでは43, 44, 44が順に表示されます(Emacs 21.3で確認)。

          fooの返す関数に使われている変数nが、Emacs Lispでは関数を呼び出した箇所の変数nを指している一方、 Common Lispでは元のfooの定義に現われる変数nを指している(そしてfooの呼出時に新たに作られた束縛を参照している)ことになります。 このことを、Emacs Lispは変数がdynamic scopeを持ち、Common Lispでは(defaultでは)lexical scopeを持つと言ったりします。

          しかもCommon Lispの変数は(defaultでは)無限のextentを持つので、fooの呼び出しで作られた束縛が、 その後の「(Paul Grahamの言う)アキュムレータ」呼び出しでも参照され、次々と更新されていく様子が分かるかと思います。 Emacs Lispでも(値が違うものの)一見数値がインクリメントされていますが、 更新されているのは、アキュムレータを呼び出している側のlet式の変数nです。Common Lispではlet式の変数nは更新されていません。

          t-nissieさんのコメント中の定義で使われているincfはEmacs Lispでは cl.el("Common Lisp extensions for Emacs")に含まれるマクロです。 「Common Lisp拡張」という名前ではありますが、 incfのようなちょっとしたマクロをそれっぽく定義することはできても、 変数のscopeやclosureまでCommon Lisp互換にするのはさすがに実現できていません。 というわけで、Paul Grahamの言う「言語の相対的な力」というのがclosureの書きやすさで決まるのなら、 Emacs LispはCommon Lispと違い、論外の超弱々言語ということになるかもしれません。:-) まあclosureは確かに便利というか、(プログラムで高階関数を使いだすと)むしろ「無いとストレスが溜る」ものなので、 Paul Graham氏の主張も分からないではないですが。

          なお、「イマドキclosureを説明するのにmutableな変数を前提とするってのはどうよ」などの突っ込みは、 Paul Grahamさんに直接おっしゃってください。 Paul Grahamの定義ではHaskellとかは相対的に弱い言語ってことになったりして? :-p

          親コメント
          • Re:標準 (スコア:2, 参考になる)

            by kr (10950) on 2006年12月03日 2時43分 (#1068822) 日記

            う、調べず書くもんじゃない……。

            「Common Lisp拡張」という名前ではありますが、 incfのようなちょっとしたマクロをそれっぽく定義することはできても、変数のscopeやclosureまでCommon Lisp互換にするのはさすがに実現できていません。
            というのは嘘でした。

            Common Lisp extensions for Emacsを使うと、元コメントのアキュムレータは以下の様に定義できます。

            (require 'cl)
            (defun foo (n)
              (lexical-let ((n n))
                (function (lambda (i) (incf n i)))))

            Common Lisp Extensionsに含まれるlexical-letを使うというのがミソですね。 このfooを元コメントのように使ってやると、ちゃんと2, 3, 42を順に表示します。 というわけで、Emacs LispもPaul Graham氏に見放されずには済みそうです。ごめんなさい。

            親コメント
            • まとめ (スコア:2, 興味深い)

              by t-nissie (8647) on 2006年12月04日 2時36分 (#1069097) ホームページ 日記
              アドバイスをありがとうございます。某所でもいろいろ教えていただきました。
              まだclosureとか本質はわかっていませんが、とりあえず各言語で試してみました。

              ● Common Lisp (CLISP。sbcl-1.0 は、Linux kernel の NPTL threading を使う
              らしく、今使っているちょっと古めのLinux Boxにはインストールできませんでした。)
              $ clisp
              [1]> (defun foo (n) #'(lambda (i) (incf n i)))
              FOO
              [2]> (defvar bar (foo 5))
              BAR
              [3]> (funcall bar 3)
              8
              [4]> (funcall bar 7)
              15
              [5]> (exit)

              ● Scheme (Gauche)
              $ gosh
              gosh> (define (foo n) (lambda (i) (set! n (+ n i)) n))
              foo
              gosh> (define bar (foo 5))
              bar
              gosh> (bar 3)   ; なぜfuncall等が不要なのか?
              8
              gosh> (bar 7)
              15
              gosh> (exit)
              ; Gaucheはreadlineがないので入力時に発狂しそうになりました。
              ; 通はEmacsから使うそうですが。

              ● Emacs Lisp (in *scratch* buffer, with C-j)
              (version)
              "GNU Emacs 22.0.91.1 (i686-pc-linux-gnu, X toolkit, Xaw3d scroll bars) ..."
              ;; Common Lisp extensions for Emacs
              (require 'cl)
              => cl
              (defun foo (n)
                (lexical-let ((n n))
                  (function (lambda (i) (incf n i)))))
              => foo
              (defvar bar (foo 5))
              => bar
              (funcall bar 3)
              => 8
              (funcall bar 7)
              => 15

              ● Ruby
              $ irb
              irb(main):001:0> def foo(n)
              irb(main):002:1> lambda {|i| n += i}
              irb(main):003:1> end
              => nil
              irb(main):004:0> bar = foo(5)
              => #<Proc:0x40222a3c@(irb):2>
              irb(main):005:0> bar.call(3)
              => 8
              irb(main):006:0> bar.call(7)
              => 15
              irb(main):007:0> qux = foo(1)
              => #<Proc:0x40222a3c@(irb):2>
              irb(main):008:0> qux.call(2)
              => 3
              irb(main):009:0> qux.call(3)
              => 6
              irb(main):010:0> bar.call(1)
              => 16   (barとquxとは独立。しかし、p bar と p qux とが同じなのが謎。)
              irb(main):011:0> exit
              --
              love && peace && free_software
              t-nissie
              親コメント
              • by kr (10950) on 2006年12月04日 5時15分 (#1069105) 日記
                某所でもいろいろ教えていただきました。

                あ、日記 [srad.jp]でですね。 すみません、気付いてなかったので「余計なもの」になってました。(_ _)

                gosh> (bar 3)   ; なぜfuncall等が不要なのか?
                これは、Schemeでは名前の関数値と変数値に区別がなく、 リスト先頭の要素も他の要素と同様に評価される(R5RSの"4.1.3. Procedure calls"のところ)からです。 なので、Schemeでは
                ((if #f + *) 3 4)
                なんてのも書けます(R5RSより引用)。

                一方Common LispやEmacs Lispでは、変数値と関数値は別々に扱われます。 Common LispやEmacs Lispで、

                (let ((list '(1 2 3)))
                  (print (symbol-function 'list))
                  (print list))
                とかやると分かると思います。 同じ名前でも関数と変数が区別される処理系では、
                (let ((list '(1 2 3)))
                  (list list))
                とか書けますが、これは逆にSchemeでは動きません。
                親コメント
        • by oldwave (20436) on 2006年12月02日 7時43分 (#1068554) ホームページ 日記

          GooやArcは、Common Lispより後に生まれた新しいLisp方言で、正直、Common Lispに飽き足らない人向けですから、これからLispを始めようという人はCommon LispかSchemeのどちらかに手をつけるといいと思います。Common LispもSchemeも多数の処理系がありますが、どちらも標準がありますよ。

          親コメント
          • by Anonymous Coward
            ケツを ] ←これで終わらせてたCommon Lisp以前の身なので
            どうも標準化ってのが、単にいろいろ不便にしてるだけとし
            か思えないまま過ぎ去った10ウン年

            (defun ac (x y)
                (cond ((zerop x) (+ y 1))
                            ((zerop y) (ac (- x 1) 1))
                            (t (ac (- x 1) (ac x (- y 1))))]

            とか

            (defun factorial (n)
                (cond ((zerop n) 1)
                     
  • by Anonymous Coward on 2006年12月02日 16時43分 (#1068652)
    たしか、これ、コメントに使うスラッシュ"/"を Unicode のダブルバイトで書いている行があって、そこにパッチ当てないとまともにコンパイルできなかったんだが・・・
  • by Anonymous Coward on 2006年12月01日 16時42分 (#1068319)
    少年よ、LISPをめざせ! 1 コメント
    ってあーた、五月のトピで1コメントって何よ、ものすごく関心薄い?

    興味本位で聞きますがLISPで大規模(人数的にの意味ね)開発する事とかあるのでしょうか?
    言語環境とか言語の生まれのせいか、一人か二人でコツコツフィードバックループで作る様な気がするんですが。

    #個人的にはemacs-lisp以外あまりさわったことないんでAC
    • Re:関連ストーリー (スコア:3, すばらしい洞察)

      by mu (9770) on 2006年12月01日 17時55分 (#1068359) 日記
      最近ではLispが書ける人間を集めてくるのが難しいということはあると思います.
      ソフトウェア的なパーツがあらかじめ想定できるような簡単な問題なら,Lispを使うまでもないかも.
      一人で開発しているだけなら,リスト構造のその場限りで構造決めて,どんどん先へ行けるという良さがあるのですが,人間が増えるとそうもいかなくなってくるのはどんな言語でも同じ.関数やマクロのすりあわせとか,いいかげん?なリストの使い方ができなくなってくると大して変わらないか..

      #多人数開発はしたことないけど,いろんな意味で開発の効率は数段は違うような気がしますけどね.
      親コメント
      • by Anonymous Coward
        元ACです。
        多人数でソフト書くときってクラス指向の言語だとオブジェクトのインターフェースのすりあわせとかその資料化とかに一番時間使うじゃないですか。(最初にきっちり決めておいてプログラマの責任境界面をちっちゃくするかわりに大人数で分割処理的な)
        LISPにおけるその界面って何なのだろうって言う疑問なわけです。
        で2,3の書き込みを見てオモッタのは、やっぱり大人数でなく人数的に小規模ですまして
        書き換えサイクルの短い開発を高速で回す感じなのだなぁと言うところでしょうか?

        • by Anonymous Coward on 2006年12月01日 20時40分 (#1068449)
          仕事でLisp書くことはありますが、あんまり大人数でやることはないですね。
          せいぜい10人まで。2〜3人が一番多いかな。
          オブジェクトのインタフェースがプロジェクトの最初の方で決められるような
          仕事なら、Lispを使う必要も無いと思います。
          だいたい、最初は何がどうなるのかよくわからん状態なのを手探りしつつ
          時には力業でわっと一度動かしてみる、ってな感じの話が多いです。
          オブジェクトのインタフェースが決まったら、実装も出来ちゃってるって
          パターン。そういう仕事だと人数増やしても効率あがらないですしね。
          親コメント
        • by kr (10950) on 2006年12月03日 6時24分 (#1068849) 日記

          どういったことを心配しておられるのか良く分からないのですが、Common Lispは言語仕様に関してだけ言えば、 多人数で問題が起こる理由は特に無いように思います。

          まず、大きなプログラムを分割して複数のグループで作っていくということであれば、 Common Lispにおいて典型的には、packageで分割することが考えられます。 packageというのは名前空間を分割する仕組みです。 PythonやRubyにも似た機能があると思いますが、 外部に対してexportする名前と内部でだけ使うinternalな名前を区別したりできます。 package名とexportする名前のところで、しっかりインタフェースを擦り合わせておけば、 各package内は他の部分に影響されずに実装できます。理屈の上では。

          muさんのコメント [srad.jp]を見ると、 Lispではなんでもかんでもリスト構造で表現するという印象があるように読めなくもないのですが、 実際にはCommon Lispでも構造体を作ることができ、内部表現が変わってもそれに対するインタフェースは変えないでおく、 といったことも一応できます。構造体参照はアクセサ関数経由になりますので、アクセサ関数の形さえ変えなければ、後からどうとでもなるということです。ですので、 「その場限りで構造決めて,どんどん先へ行」ってしまっても、後でプログラムの他の部分を変更することなく、 構造だけ考え直すとかいうことはできます。最初に決めたインタフェース自体が駄目だった場合苦労するのは他の言語同様ですが。

          「クラス指向」でないと駄目ということでしたら、 Common Lisp仕様にはCLOS [wikipedia.org]というオブジェクト指向システムが含まれています。 これはANSI仕様にも入っていますので、ANSI Common Lisp準拠の処理系(SBCLとか)なら使えるはずです。 C++やJavaとはちょっと毛色は違いますが、クラスベース(ECMAScriptなどのようなプロトタイプベースでなく)オブジェクトシステムになっています。

          クラス指向の言語だとオブジェクトのインターフェースのすりあわせとかその資料化とかに一番時間使う
          というような開発方法をとりたければ、CLOSベースでインタフェースを決めるのも手かもしれません。 実際にはpackageも一緒に考えることになると思いますが。

          ……というように、言語仕様上は多人数開発もOKかと思うのです。 しかし、大きなプロジェクトをCommon Lispで立ち上げるのが難しいとしたら、 それはやはりmuさんも指摘しておられるように、Lispを使える開発者が集まらないという点に問題があるんだと思います……。orz
          ;; 最近そこそこ多人数なC++でのプロジェクト内で「ああっ、ここLisp(もしくはScheme等々)ならもっと楽に書けるのにっっ」とか
          ;; (心の中で)叫ぶ日々を送ってます。(T_T)

          親コメント
        • by Anonymous Coward on 2006年12月01日 19時55分 (#1068425)
          あらあら、かぐわしい話題が進行してまつね

          こちら [msi.co.jp]のリンクはってみますね。
          親コメント
          • by Anonymous Coward
            #1068425さんの主旨が判らないんですが、次のどれでしょうか?

            (1) 納豆相手にくさやを出して、納豆の方が臭い
            (2) 納豆相手にくさやを出して、くさやの方が臭い
            (3) 納豆相手にくさやを出して、どちらも臭い
            (4) 納豆相手にくさやを出して、どちらも芳しい
    • by etsav (7596) on 2006年12月01日 17時08分 (#1068338) 日記

      大規模って程大規模ではなかった(二十人は越えなかったかな?)ですけど、 数年間、 主に Common Lisp で開発してた研究プロジェクトに派遣されてたことがありますよ。 AI・自然言語処理がらみでした。

      処理の速さよりも、 特定分野での書き易さ(開発の速さにつながる)でしょうかね、 Lisp の利点は。 『手続き』ではないものを、 わざわざ『手続き』に翻訳しなくてもいいので。

      ;; Native Lisper ではないので、
      ;; あんまり偉そうなことは言えないけど。

      親コメント
    • by mu (9770) on 2006年12月01日 18時05分 (#1068367) 日記
      > 少年よ、LISPをめざせ! 1 コメント
      > ってあーた、五月のトピで1コメントって何よ、ものすごく関心薄い?

      日付は2001.5.10ですよ.
      そして,このスラッシュドットジャパンが始まったのは2001.5.28
      http://srad.jp/about.shtml [srad.jp]
      親コメント
      • by Anonymous Coward
        5年間で二つしかストーリーがないなんて、 「ものすごく関心薄い」どころか、存在が無いも同然ですね。
    • by superfox (31908) on 2006年12月01日 16時52分 (#1068329)
      プロジェクトの一部として活用したりしますよ。

      1)Lisp インタプリタ作る
      2)簡易言語的な wrapper 作る
      3)目的に応じた要素篇を人海戦術で作らせる

      とかね。
      親コメント
    • by Anonymous Coward
      5〜10名くらいでウェブサーバを作ってた事がありました。

      # 大規模とは言えないですけどね、、、
    • by Anonymous Coward
      私の関心のある(お世話になっている)分野のプログラムでcommon lispを使っているものというと、
      computer algebra system(数式処理)のMAXIMAが思い浮かびます。
      数学とLispの両方に通じていないといじれない為、大規模とはいえませんが。
      amd64なマシンでは、clisp,sbcl等が使えるので、 暇を作って新しいsbclを試してみようとは思います。
  • by Anonymous Coward on 2006年12月01日 19時29分 (#1068415)
    しばらく見なかったらWindows Portもあるんですね。
    ちょっくら使ってみようかな。
  • by Anonymous Coward on 2006年12月01日 19時57分 (#1068426)
    タイトル見てソフトバンクがまた何かやったのかと思ったのは私だけではないはず。
  • by Anonymous Coward on 2006年12月02日 10時18分 (#1068574)
    時代は今、関数型言語のパラダイムを求めているんだね。 Java クロージャしかり、Lambda Camel Perl 6 しかり。 オブジェクト指向もあるし Common Lisp の再興の時来たる、 って感じなのかね。
    • by kr (10950) on 2006年12月03日 8時26分 (#1068860) 日記

      Lambda Camel Perl 6って何なのか知らないのですが、Perl 6では従来のclosureの他に、blockがすべてclosureと見做されるようになって、新しい記法が追加されるという [perl.org]の関連でしょうか?

      λの時代なのかどうかは正直よく分かりませんが、 Javaにクロージャ [srad.jp]のストーリーでも 紹介 [srad.jp]されているように、 C++にもlambda式を入れる提案があるようで。もしかすると流行ってるのかなあという気もちょっとしますね。LISPは通り越してML系の言語を目指してる気もしますが。

      オブジェクト指向が流行った(?)おかげで、今やCOBOLの仕様すらオブジェクト指向を取り込んでるそうですが、 関数型言語が本当に流行ったら、そのうちFUNCTIONAL COBOLなんてのも登場するんでしょうか。:-)

      親コメント
  • by Anonymous Coward on 2006年12月02日 11時58分 (#1068589)
    処理系が多すぎるのがLISPの普及を妨げてると思うんだよね・・・ 筋はいいのに、あちこちにリソースが分散されてる上に、 新規に興味を持った人がどれを使えばいいのかわからない。
    • by mu (9770) on 2006年12月02日 12時54分 (#1068598) 日記
      うーん,昔はともかく最近は
      CommonLispとScheme
      に収斂してきているような気がしますが.
      あとEmacsのelispぐらいでしょうか.

      #まあ,普及してないのは当たってますがorz
      親コメント
      • 規格というか仕様としてはその二つが鉄板でしょうが、
        処理系となると標準てありますか?
        まさか全ての処理系がまったく同じ挙動という訳ではないでしょう?
        • by Anonymous Coward on 2006年12月02日 23時37分 (#1068766)
          >処理系となると標準てありますか?

          その見方は新しいかも。

          例えばCなら標準に対して様々な処理系があってそれぞれに使われています。一方でPerlやJavaのように比較的新しい言語はまず実装ありきで、標準規格のないものも少なくないです。

          # 最近の言語でもECMAScriptやC#は例外か

          LISPやSchemeは割と古い言語で標準規格もある。実装もいくつかある。そういう意味でCに近い気がします。

          >まさか全ての処理系がまったく同じ挙動という訳ではないでしょう?

          たしかにそうですが標準規格と異なる挙動はバグです。LISPに限らずバグによる誤った挙動を期待することは、いつ梯子を外されるかわからないため危険です。様々な制約によりworkaroundする時もあるけれど、それもLISPに限らないですよね。
          親コメント
typodupeerror

吾輩はリファレンスである。名前はまだ無い -- perlの中の人

読み込み中...