Lisp Scheme Part40 [転載禁止]©2ch.net

■ このスレッドは過去ログ倉庫に格納されています
2015/03/16(月) 13:45:52.92ID:EEYZoZ1i
Common Lisp、SchemeをはじめとするLisp族全般のスレです

■前スレ
Lisp Scheme Part39
http://peace.2ch.net/test/read.cgi/tech/1408017352/

■テンプレ
ttp://wiki.fdiary.net/lisp/

■関連スレ
【入門】Common Lisp その11【質問よろず】
http://peace.2ch.net/test/read.cgi/tech/1411307361/
【Scheme】Schemeインタプリタ Mosh Part1【Lisp】
http://peace.2ch.net/test/read.cgi/tech/1272469779/
【Lisp】プログラミング言語 Clojure #3【JVM】
http://peace.2ch.net/test/read.cgi/tech/1380333808/
【魔法】リリカル☆Lisp【言語】
http://peace.2ch.net/test/read.cgi/tech/1183396621/
2015/06/19(金) 08:57:20.33ID:688YE8UT
>>98
後者
2015/06/19(金) 11:01:47.02ID:tBR6vKOw
>>98
Lisp慣れしてない自分でもClojureに楽しくはまったのでClojureを押してみるなり
JVM用言語で最も短いコードで最良の結果だす言語の一つだと感じる
2015/06/20(土) 11:39:42.60ID:rk/B/nZr
>>98
後者。
Leiningen の checkout dependency が便利すぎてはげる
2015/06/22(月) 11:59:19.90ID:2Ao8Xtyy
モナドのちゃんとした定義ってあるの?
言語ごとに定義が違う気がするんだけど
2015/06/22(月) 14:13:40.72ID:FwurGF7a
モナド則はモナド則だよ。
104デフォルトの名無しさん
垢版 |
2015/06/22(月) 20:47:07.39ID:unToOooi
関数型言語「Racket 6.2」リリース
http://osdn.jp/magazine/15/06/23/063900

 RacketはShemeから派生した関数型言語。旧名称はPLT Schemeで、バージョン5より
Racketに名称を変更した。強力なマクロシステムが特徴で、マクロを使って言語機能
を拡張でき、プロジェクト固有の新しい「方言」を作成できるという。また、Web
サーバーやデータベース、GUI、チャートなどのアプリケーションをサポートする
ライブラリも提供される。ライセンスはLGPL。プロジェクトは米国立科学財団(NSF)、
国防高等研究計画局(DARPA)、米教育省、Exxon Foundation、Microsoft、Mozilla、
Googleなどの支援を受けている。
2015/06/22(月) 23:08:50.19ID:SUvAdIcO
Racket 最強伝説
106デフォルトの名無しさん
垢版 |
2015/06/23(火) 00:34:37.16ID:ZAN95P/B
>>104
記事読んだけど、マルチパラダイム言語って誰が言い始めたんだろ
そもそもシングルパラダイム(原理主義)な言語なんて非実用的なものの対義語なんか冠にしても意味ないと思う
2015/06/24(水) 10:17:09.07ID:fsHZ6HK+
typed-racketが変なバグ起こさなくなったの?
安心して使えるようになったのなら使ってみようかな
2015/06/24(水) 18:03:08.01ID:jBd8hVQL
Clojureと同じ文法でC++もwrapしようとしてるプロジェクトを
2つぐらいみつけたんだが2年ぐらい更新がない
JavaからC++の変換はそんな難しくないはずなんだけど
何か違う理由で頓挫してるんだろうか
2015/06/24(水) 23:03:41.63ID:+qhy7yF2
>>108
(その人達に必要な機能は)完成したからではなかろうか
2015/06/24(水) 23:46:08.20ID:PBiySlld
試しに実装してみたぐらいの気がする。
継続して使うのに作ったかは分からない。


型付きといえばshenも、18.1で型チェックが速くなったらしい。
ソースみたら、該当箇所の型が総称型に変わってた。
http://www.shenlanguage.org
2015/06/24(水) 23:50:28.07ID:PBiySlld
相互運用テストのためにakamaiがhttp2のコードをCLで書いてて、少し話題になってたね。
https://github.com/akamai/cl-http2-protocol
https://github.com/http2/http2-spec/wiki/Implementations
2015/06/24(水) 23:56:47.57ID:PBiySlld
cl-llvmってなんだろう。
https://github.com/sellout/CL-LLVM
llvmを吐く?FFI?

http://blog.cnu.jp/2012/12/11/android-gdk/
それとも、androidのjava/llvmみたいな話と同じなのかな?
2015/06/25(木) 00:00:46.68ID:1wCihy2Z
これ3年ぶりのコミットがあったのか。
https://github.com/sellout/CL-LLVM/commits/master
2015/06/25(木) 13:36:07.50ID:q+JEbLja
CL (というより動的型の言語) は LLVM の抽象度では上手く扱えないしたいして最適化できないという話もある。
GC の性能にも強く左右されるし、 LLVM よりも JVM の方が CL とは相性よさそうな気がする。
2015/06/25(木) 14:00:35.66ID:NeoIiVi2
ABCLの性能ってどうなの?
2015/06/28(日) 19:28:01.75ID:8Yznu8U0
昔,kawaからJavaを使おうとして非常に苦労した記憶が
ABCLならだいぶ楽にJavaが使えるのだろうか
Clojureは最初は楽だけどJavaのパッケージマネージャで苦労するね
2015/06/30(火) 06:09:22.32ID:OHT0M0qn
>>116
Java のパッケージマネージャって Clojure 書くのに Maven とか Gradle でも使ってるの?
118デフォルトの名無しさん
垢版 |
2015/07/05(日) 11:29:59.98ID:dGwooAgp
一時期Clojureが過剰に持ち上げられていたけど
まったく流行らずに終わったな
2015/07/05(日) 12:29:23.07ID:Fkt4l860
ブラジャーに対抗しようとしても無駄なことだし
2015/07/05(日) 23:54:46.16ID:6U0/+Enp
clojure は、lispの対抗馬とか思ってると、 repl 起動するまでにブチ切れると思う
2015/07/06(月) 05:13:14.19ID:lUS8hza0
普通に流行ってるじゃん
2015/07/06(月) 14:46:34.49ID:Mc9Nlxok
やもえずJavaのウンコなプログラムのメンテしないといけない場合に
Clojureは便利だった

そういう制約ないならRacketが一番
123デフォルトの名無しさん
垢版 |
2015/07/06(月) 16:16:59.97ID:VRJTYjkB
>>122
Racketの良さを教えて
2015/07/06(月) 17:47:41.11ID:Mc9Nlxok
srfiがみんな使える上に
pythonとも連携できる
jythonみたいにnumpyが動かないとかもない
125デフォルトの名無しさん
垢版 |
2015/07/06(月) 18:34:53.65ID:VRJTYjkB
>>124
ありがとう
pythonライブラリを透過的に使えるなら便利そうだね
2015/07/06(月) 20:10:10.03ID:XAQcetl+
えっ?Clojure って流行ってるの?
2015/07/06(月) 21:13:41.58ID:4dWpMilG
少なくともメーリングリストは相当活発だよ
128デフォルトの名無しさん
垢版 |
2015/07/06(月) 21:14:58.54ID:VRJTYjkB
自前でサーバー立てるなら何でもありだけど、実際PaaSのほとんどがJVM前提だからね
2015/07/07(火) 02:14:08.64ID:FANO5u+E
Javaでプログラム書く人達はユニットテストという概念がないらしく
csvに結果を書き出してエクセルで手作業テストを行うという謎慣習があるようだ

こういう人達の書いたJavaコードと付き合わざる得ない環境ではClojureは便利
2015/07/07(火) 05:31:59.64ID:3YG+ylqQ
JUnit…
2015/07/07(火) 13:05:55.75ID:FANO5u+E
eclipseからJUnit使ってみるとわかるけど
エクセルの方が楽
132デフォルトの名無しさん
垢版 |
2015/07/08(水) 00:15:24.50ID:j/rYw6w7
>>129
むしろ、java以外のユニットテストツールを使ったことがない
133デフォルトの名無しさん
垢版 |
2015/07/18(土) 20:06:26.43ID:cOkep0vN
>強力なマクロシステムが特徴で、マクロを使って言語機能を拡張でき
このLISP系でよく言われる「言語機能の拡張」って全然的を射てねーなと思う
例えばschemeのファーストクラスオブジェクト(FCO)としての継続って
言語プリミティブとしてFSO継続相当を始めから持ってない限りはどうやっても
拡張で得ることはできないし
FCOとしての継続の無い言語から有る言語へ言語機能を拡張するってことは
つまり新規にFCO継続付き言語を作るって事に他ならない
できることは結局言語に既にある機能の延長上の事だけで
言語拡張なんて大それた事は他の言語同様できやしない
「子供騙しですけど強力なマクロシステムで俺構文糖衣が簡単に作れますんで・・・」
とちゃんと書き直した方がいいね!
「プラグインモジュールを使うと言語機能を拡張できます」とかで売った方がまだ納得できると
思わないかね君たち
2015/07/18(土) 23:28:49.86ID:uE0O9hZ+
長くて読めないから3文字にまとめてくれ!
135デフォルトの名無しさん
垢版 |
2015/07/19(日) 00:51:10.84ID:yGfbtuav
おかしなひとには
かかわらない
しらんぷり
2015/07/19(日) 05:55:05.73ID:9T0GJGKU

 か
  ん
2015/07/19(日) 06:44:26.04ID:D56BGbCW
>>133
思わない
2015/07/19(日) 06:46:11.77ID:D56BGbCW
>>133
ていうか頭悪いと思います
「言語拡張」の俺的意味からの演繹をしてるだけ
2015/07/19(日) 07:08:41.31ID:rCpqRDah
マクロ展開時になんでもできるのに何で制限があると思うんだ?
140デフォルトの名無しさん
垢版 |
2015/07/19(日) 12:23:56.55ID:HOCsiBj3
>>133 みたいな勉強不足の人に黒板先生は本当に便利だ

http://cl-www.msi.co.jp/solutions/knowledge/lisp-world/articles/scheme

> 端的に言ってしまえば Scheme は Lisp ではないです。 この2つを混同するのは味噌糞いっしょ、ってやつで、つつしむべきです。

http://cl-www.msi.co.jp/solutions/knowledge/lisp-world/articles/script-lang

> Lisp の不幸の1つに、
> Lisp を使わない奴に限って Lisp について語りたがる
> というのがあるんですが、今回もう1つ加わったのは、
> Lisp を知らない奴に限って Lisp を他のもの、なかでも自分の自慰行為の結果と比べたがる
> Lisp の評論をとうとうとやるわけです。
2015/07/19(日) 12:48:48.02ID:UMlSSY6R
>>133
マクロは任意の構文木から任意の構文木への変換であって
どんなプリミティブが用意されるかは言語の戦略で決まること
レイヤーの違うことを関連付けて語るのはやめてちょうだい
142デフォルトの名無しさん
垢版 |
2015/07/19(日) 13:33:11.61ID:4YSiYgLI
>>140
その理屈でいくなら、CommonLisp も Lisp ではありませんね
143デフォルトの名無しさん
垢版 |
2015/07/19(日) 13:42:12.63ID:HOCsiBj3
>>142
それと >>133 とどんな関係が?
144デフォルトの名無しさん
垢版 |
2015/07/19(日) 13:58:30.31ID:4YSiYgLI
>>143
Lisp と CommonLisp を混同しながら、Scheme はLisp ではないと主張ている人の意見はほどほどにして聞きましょう
145デフォルトの名無しさん
垢版 |
2015/07/19(日) 14:18:17.54ID:HOCsiBj3
>>144
自身のLispの定義を明らかにせずにCommon Lispは違うって言われましてもw
でもCommon LispがLispでないんなら、なおさらSchemeでLispを代表させるような論が成立しないのは同意できるんでないの
146デフォルトの名無しさん
垢版 |
2015/07/19(日) 15:30:05.25ID:4YSiYgLI
>>145
まず、Lisp は CommonLisp ではない
Lisp は Scheme ではない

次に
ttp://www.softwarepreservation.org/projects/LISP/book/LISP%201.5%20Programmers%20Manual.pdf
この↑Lisp1.5 は Lisp であるとする (おそらく、誰も異議をはさまないでしょう)

その上で、CommonLisp は Lisp であると仮定する (つまり、Lisp1.5 と CommonLisp程度の差があっても Lisp の一部であると仮定する)
当然、SchemeはLispである

逆に、SchemeはLispではないと仮定する (つまり、SchemeにもLisp1.5にもないモノがあればLispではないとする)
package にintern できる symbol がある CommonLisp は Lispではない

CommonLisp 側の言い分としては、CommonLisp はSchmeと同じくLisp系の新言語です
(Common Lisp is the modern, multi-paradigm, high-performance, compiled, ANSI-standardized, most prominent (along with Scheme) descendant of the long-running family of Lisp programming languages. )

Confusing Lisp and Common Lisp is permissible once in a human life. です

個人的には、マクロやシンボルが無くてもLispと呼ぶべきだと思います
2015/07/19(日) 16:16:48.77ID:heZn3Xco
>>140
このKURODA Hisaoって人が書いてる他のページも見たが
Abstract Syntaxの概念やこれを設定する意義を理解できない人がSemanticsについて語っても全く説得力がないね
それにSchemeの単一name space批判を自然言語での文脈依存性を持ち出してるが
自然言語の柔軟さというかいい加減さを至上の価値とするのならば所詮は知性ゼロ・常識ゼロのコンパイラやインタプリタですら処理できちゃう
普通のプログラミング言語なんてどれも失格、もちろんCommon Lispもね
理論や論理学について良く判っていない人間ほどFregeみたいな「計算機と深い関係があると世間で言われている」哲学者の名前を出したがる
2015/07/19(日) 16:17:03.59ID:OiytaaWT
 わりと
   どうでもいいよね〜                   ね〜♪
                         _ ‐..::  ̄ ̄ ::::... 、
              . ィ            r'::/ ::ィ:::::::::::j:::::::ヽ::::\
,._.._ .......、._    _ /:/l!            | ::|::/ |::::::::∧:::レ::l:::| :::::rヘ
ヽ :~""''.>゙' "~ ,、、''‐'、|          l ::仏_ノヘ:/ ー- ハ:::!::::::|::::i
 ゙、'、::::::ノ:::::::_,.-=.  _〜:、          /::::リy=ミ ' ィ=ミ /:::::!::::/:::::!
  ``、/:::::::::__....,._ `゙'Y' _.ェ-、..._      |::::{xx     xx/::::::「)'|:::::::|
  ,.--l‐''"~..-_'.x-='"゙ー 、`'-、      lハ:仆 ..._ヽフ /:::: /´ |:::::::|
 "   .!-'",/  `'-‐'') /\ `      Y::::ソ勺 7イV_  !:::::::!
  .-''~ >'゙::    ‐'"゙./  ヽ.    __  |::/ 爻___ん'´ッ'⌒ヽ! :::::!
    //:::::       ',        (__,、\/ /‐―一弋{、  /  ̄_)
   ' /:::::       .:';          \ ' {      :::\   /~::!
2015/07/19(日) 17:56:45.41ID:D56BGbCW
チンコも関係ないもんねぇ
2015/07/19(日) 17:57:39.68ID:KxDpt4xY
これで133も満足だね
2015/07/19(日) 18:28:12.53ID:yGfbtuav
確かに言語拡張でarduinoと連携してドローンを自動航行できますとか言えた方がかっこいいよな
方言作れるとか書かれてもLisp界隈の事情知らん人間にゃ意味不明だし
2015/07/19(日) 20:49:45.79ID:bZkSJoy2
>>151
バインディング書けば言語に関係なく出来るだろ。
その手のライブラリがたくさんあるとか、
コマンドひとつで導入できるエコシステムがあるとかならアピールポイントになるとは思うけど。
2015/07/19(日) 22:15:40.89ID:+t5BUUhH
言語は大きい会社や団体が開発してることがほとんど。なので妙な政治意図で故意に機能が削られたりが良くある。マクロありとこういうのは無視出来る。だいたいは誰かが便利なマクロを公開してくれる
2015/07/20(月) 00:59:43.37ID:jCSJmRBw
なんで誰もcl-contを持ち出さないんだ
2015/07/20(月) 01:22:41.63ID:8KYV1D+J
だって、>133の言い掛かりと言語レベルでの継続の必要性とは、まるで関係がないんだものw
2015/07/20(月) 02:49:25.74ID:kupXshGu
フル継続の後付けが難しいのは事実だろ。
cl-cont も Scheme に比べればモドキに過ぎないしな。

そんでもって >>133 は継続は例に出しただけで、
マクロによる拡張が容易であっても言語が持つべきプリミティブの選択が重要だってことじゃないのか?
2015/07/20(月) 17:42:45.96ID:aIRgWq4T
長々書いてるけどマクロでシンタックスを拡張できてもセマンティクスは変えられないってこと?
そりゃそうなんじゃない?この手の話の根はチューリング完全話と一緒だよね
機能拡張という言葉はセマンティクス拡張と同義ではないよなあ
2015/07/20(月) 20:43:14.25ID:ysx1EkA6
それはもう見ているものがLispのマクロによる拡張性ではなくなっている
2015/07/20(月) 21:51:34.43ID:d8TisZYV
特殊形式以外のマクロを使わないという選択
2015/07/20(月) 23:07:56.79ID:kupXshGu
言語の意味論とシンタクス拡張はレイヤが違う話だよ。
DSL は言語の意味論を変えはしないけど系を作ることは出来る。

物理法則は変えられないけど、物理法則の範囲内でサッカーのルールを定義したとして、それが無意味って言えるか?
2015/07/21(火) 18:19:47.73ID:3UOplv+P
上の方の人と偶然被ってるけど、質問。
schemeのdefine-syntaxって何ですか?
defineじゃダメなの?
2015/07/22(水) 02:27:20.21ID:ta5d120D
Scheme のマクロは式の評価の前に展開される。
ものすごく単純化して説明すると処理されるタイミングが違うの。
2015/07/22(水) 10:24:48.10ID:4IMBgQFd
>>161
マクロなら可能だがdefineでは定義不可能なケースを上げておく

defineで定義された関数(procedure)の適用では、まず全ての引数が評価されてからその結果が関数bodyに渡されて関数の結果が決まる。
もし、全ての関数を評価せずに前から必要な分だけ評価する関数を書きたい場合、defineでは無理。その場合はdefineは-syntaxなどをつかってマクロを定義することになる。

マクロは
>>162が述べているように第一段階としてSchemeのS式を生成し、第二段階でその生成されたS式を評価するわけだが、第一段階ではマクロの引数は評価されない点が重要。
それによって、defieとは異なり一部の引数をのみ評価することが可能となる。

or関数はその一例だな
もしdefineでmy_orを定義しようとすると全ての引数を評価するという無駄な関数となるわけだ。
もしaがtrueなら
(or a b c d e)でb以下は評価不要
が(define my_or ……)とすると
aからeまでを必ず評価してしまう
2015/07/22(水) 10:26:49.67ID:TPXSOrgT
>>163
補足
だからmy_orはマクロで定義するというわけな
どうだ?
チンコそそり立つほどわかったか?
2015/07/22(水) 10:28:22.27ID:TPXSOrgT
>>163
訂正
もし、全ての関数を評価せずに
もし、全ての引数を評価せずに
2015/07/22(水) 13:29:11.06ID:wcjgZ6Dx
>>162でスゲーわかった気になったのに、>>163-164で全然わからなくなりました。
defineでも問題なさそうだけど。

(define my_or1
(syntax-rules ()
((_ a b) (or a b))))

(define-syntax my_or2
(syntax-rules ()
((_ a b) (or a b))))

(my_or1 #t (begin (print "!") #f)) ===> #t
(my_or2 #t (begin (print "!") #f)) ===> #t
2015/07/22(水) 21:13:51.17ID:ta5d120D
>>166
試した処理系は何? それは仕様上未定義だよ。
期待した動作をするように見えてもただの偶然。
2015/07/23(木) 00:05:16.72ID:a8nLYx9Z
全部(lambda()〜)で囲って遅延評価すればなんでもできるよ
SICPでマクロが無くても問題なかったのはこのおかげ
2015/07/23(木) 01:48:45.97ID:6c5WF/G8
>>167
gaucheっす。r[567]rsによると、my_or1はこう呼ぶべしと理解したけど、あってます?
(define my_or1 (syntax-rules () ((_ a b) (or a b))))
(let-syntax ((my_or1 my_or1)) (my_or1 #t (error "!!")))

変数と構文キーワードを区別しなきゃならない理由が、いまいちピンときません。
フォームの先頭が(lambda)を評価したものと(syntax-rules)を評価したもので
区別出来そうな気がします。(実際Gaucheはそうしてるから>>166で動いてる?)
2015/07/23(木) 02:53:10.55ID:kIXXXoPi
>>169
構文は第一級ではない。 (実行時に値として扱える存在ではない。)
「マクロ展開フェイズ」が完了してから「式の評価」を開始するので、実行時に束縛するのでは遅すぎるんだよ。

式ひとつごとに「展開」「評価」をする処理系でフェイズの分離を有耶無耶にしている処理系だと区別を曖昧にしてもなんとかなるのかもしれないが……
それは実装方針のひとつとしてそういうのもありえる、可能というだけ。
2015/07/23(木) 03:19:31.89ID:6c5WF/G8
>>170
>構文は第一級ではない。 (実行時に値として扱える存在ではない。)
なるほど、疑問氷解です。
2015/07/28(火) 17:18:38.84ID:HAkHyXxd
.oO( The Little Prover を読んだ香具師がスレの流れを作ってくれる予感 )
2015/07/29(水) 02:05:40.80ID:CRqVMe5R
なぜ自由なlispより不自由なjavascriptが流行ったのか
2015/07/29(水) 02:07:56.15ID:c7scFQol
自由度なんてマニアしか求めてないから
2015/07/29(水) 08:09:17.38ID:F/xNpz+P
ウェブブラウザから使えるのが lisp だったら流行ったんじゃないの?
とはいえそこに lisp が採用されない理由も結局は一緒か。
2015/07/29(水) 20:06:45.42ID:amFWHOPf
IE4やNN4で実装されたスクリプト言語がLISP系だったら…

少なくともfirefoxのnoscriptアドオンは不要だったろうな
2015/07/29(水) 22:07:49.45ID:Gvu0+gpo
逆に考えるんだ、
「lisp でWebブラウザを作ればいいや」
と考えるんだ
2015/07/29(水) 22:20:24.82ID:w5hc2Qux
WebAssembly が一般的になれば Lisp にもワンチャンあるで
2015/07/30(木) 00:29:45.75ID:5uamD/zW
Javaがダメ言語とあの時点で判明してればなあ。
当初の予定通りschemeが組み込まれてたに違いない。
2015/07/30(木) 00:35:22.22ID:W1QWz47r
emacs で Webブラウジングが出来るんじゃ無かったか。
2015/07/30(木) 00:51:21.10ID:bNQ7YEFA
技術系のドキュメントとかあまり凝った事してないものしかまともに見れんよ。
2015/07/30(木) 01:08:52.34ID:txS92Tc7
Emacs に Webkit 載せたりしてるのもあったぞ。
Emacs 側から Webkit をどれくらい操作できるのかは知らんけど。
2015/07/30(木) 03:10:36.45ID:qAED+lXR
ブラウザ競争っていかにCSSに意図通り対応してるかの勝負だし
サーバサイドならemacsでもjavaでも変わらん
2015/07/30(木) 22:45:29.66ID:e7NCTD1Y
いや javascript が動かないと。

ああ、其処を lisp にするって話だったか。
2015/07/30(木) 22:47:36.32ID:lQHnBAth
いまだに、javascript が scheme だということについて納得できない
2015/07/31(金) 01:38:43.67ID:aJuGxMgm
第一級の継続も末尾呼び出しの最適化もないしねぇ

手続きが無条件でクロージャになるってのがまあ当時としては特徴的ではあったけども
2015/07/31(金) 15:13:29.83ID:Dkg4afbG
CLみたいな余計な装飾子が無いところはschemeと考え方が近い
末尾最適化が標準のluaのがよりschemeに近い
継続は第一級にする必要ってあんのかな
使い所が難しいし言語に例外機構が備わってればいらないし
jsはライブラリ覚えるだけでもしんどい
2015/08/01(土) 07:34:04.74ID:qWCT4wa1
今JSがコールバック地獄になってるからこそ継続がほしいんじゃん。フル継続じゃなくて限定継続でもいいから。
2015/08/01(土) 10:30:34.72ID:c0YSrVc+
javascriptのように通信が頻繁に行われる環境で継続なんか入れたときに、例えば途中でブラウザを切ったときの継続がどうなってるのか考えるとワケ分からなくなる
schemeの継続ですら、資源を使いまくってるサーバが落ちたときにリソースのclose操作とかきちんと行われるのか不安になる
2015/08/02(日) 01:56:02.37ID:MF9TQU9s
>>188
jsはクロージャがあるからCPS方式で継続もどきは作れるんじゃないの
インスタンスが途切れちゃうなら継続使っても同じだし
191デフォルトの名無しさん
垢版 |
2015/08/03(月) 18:40:37.91ID:zmSfrGKJ
>>190
CSP?
2015/08/03(月) 23:15:17.18ID:TaloxJI9
継続渡しはCPS
セントラル警備保障はCSP
2015/08/04(火) 03:41:56.42ID:T8IrycSA
JavaScript 処理系の Rhino は第一級継続を持ってる。 実在する以上、言語処理系レベルでは可能ってことだろ。
だけど、 Scheme 処理系でも外部のライブラリ (バインディングとか) を通過したところで継続が途切れてしまう制限を持っているものがあることからもわかるように、
継続が処理系の外の世界をまたぐのは難しいんだわ。
(※参考 Gauche のドキュメント http://practical-scheme.net/gauche/man/?l=jp&;p=call/cc )

JavaScript はアプリケーションに組込んで使うタイプの言語だから、当然、外の世界とのやり取りはあたりまえで、
そこに第一級継続を持ち込んでも途切れまくりであんまり役に立たんのじゃないか?

Gauche のドキュメントには限定継続の利用を勧めるようなことも書いてあるけど、
フル継続で途切れてしまうところを越えられるって意味ではなくて、
継続の範囲を明確に書けるから変なところをまたがないように注意しやすいって意味だと思う。
2015/08/05(水) 21:47:02.17ID:PeKQT7A5
プログラミングGauche第2版マダー
2015/08/05(水) 22:50:49.33ID:Vg22nrpW
そういやGNU標準言語?だかのはずのguileって使われてるんだろうか
2015/08/06(木) 08:01:11.84ID:e5V4W5I+
待ちguile
2015/08/06(木) 22:25:04.23ID:JI2t4Gst
GNU自体微妙な団体だし
そんな団体の標準になられても気持ち悪い
2015/08/06(木) 23:00:12.98ID:lTjoYGg1
などとにわかschemerが申しております
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況