EssenMemo0011
の編集
http://khfdpl.osask.jp/wiki/?EssenMemo0011
[
トップ
] [
編集
|
差分
|
バックアップ
|
添付
|
リロード
] [
新規
|
一覧
|
単語検索
|
最終更新
|
ヘルプ
]
-- 雛形とするページ --
2016_10
2016_11
2016_12
BracketName
Essen
Essen0
Essen1
Essen2
Essen3
Essen4
EssenMemo0001
EssenMemo0002
EssenMemo0003
EssenMemo0004
EssenMemo0005
EssenMemo0006
EssenMemo0007
EssenMemo0008
EssenMemo0009
EssenMemo0010
EssenMemo0011
EssenR2
EssenR2_ess03f
EssenR2_ess03h
EssenR2_ess03i
EssenR2_ideas
EssenR2_jit00
EssenR2_jit01
FormattingRules
FrontPage
Help
IP
InterWiki
InterWikiName
InterWikiSandBox
K
KHPC
KHPC_v000doc01
KHPC_v001doc01
KHPC_v002doc01
KHPC_v003doc01
MenuBar
OSC
OSC20181027
OSC20190222
OSC20191123
OSC20230401
OSC20230528
OSC20231021
OSC20240310
OSC20241026
PHP
PukiWiki
PukiWiki/1.4
PukiWiki/1.4/Manual
PukiWiki/1.4/Manual/Plugin
PukiWiki/1.4/Manual/Plugin/A-D
PukiWiki/1.4/Manual/Plugin/E-G
PukiWiki/1.4/Manual/Plugin/H-K
PukiWiki/1.4/Manual/Plugin/L-N
PukiWiki/1.4/Manual/Plugin/O-R
PukiWiki/1.4/Manual/Plugin/S-U
PukiWiki/1.4/Manual/Plugin/V-Z
RecentDeleted
SandBox
SltVA
VariableArray
WikiEngines
WikiName
YukiWiki
advcal20161205
advcal20161206
advcal20161209
advcal20161210
advcal20161215
eoml0001
eoml0002
essen_ex01_0001
impressions
kcl_malloc
khfdpl_result1
members
memo0001
memo0002
note0001
note0002
note0003
note0004
note0005
note0006
oldworks
oldworks00
oldworks06
oldworks12
oldworks13
osaskjp_index
persistent_C
populars
pr20161105
pr20161105b
scsc
seccamp2017
spam_test
uxf
uxf_01
uxf_02
uxp
* 言語自作に関する思いを書く -(by [[K]], 2018.01.20) ** (1) -[Q] なぜインタプリタにこだわるのか?#1 --[A] インタプリタなら、実行しない部分をちゃんと書いておく必要はない。それがうれしい。 --開発中に「とりあえずここまでで実行してみるか」って思ったときに、「宣言されていない関数を呼び出している部分があります」っていうエラーが出てくるのが本当にうっとうしい。「そこはどうせテスト実行しない部分なんだからどうでもいいだろ」って思うのに・・・。 --それでダミー関数を置いたりするわけだけど、それが効率のいいやり方だとは到底思えない。 --他にも宣言していない変数を参照しているとか、そういうエラーもうっとうしい。だからそこは今回は実行しない部分だからどうでもいいって言っているのに! -[Q] なぜインタプリタにこだわるのか?#2 --[A] インタプリタなら、eval命令を容易に実現できる。つまりプログラムでプログラムを生成し、それを直ちに実行できる。実行中に自分自身に関数や構造体を追加したり削除できたらどんなにいいだろう。 --いまでもC言語などでは機械語を出力して実行することはできる(JITコンパイラは基本的にそうやっている)。でも機械語を出力するので機種依存がある。機械語を出力するので、難易度が高い。EssenならEssenのプログラムを出力するだけでJITコンパイルをできるようにしてやろうではないか。 -[Q] プリプロセッサは排除したいのはなぜか? --[A] ただのテキスト置換で言語の機能を補うというのは、うまいやり方ではない。#defineで関数もどきを書くときに、演算子の優先順位を何とかするために引数をカッコでくくるとか、バッドノウハウにしかみえない。そんなのが正解なんだろうか。 --同じことがしたいのならinline関数で代用できるべきだし、#defineでやったほうが効率がいいのなら、それはもはやinline関数のほうを改良すべきなのであって、プリプロセッサによるテキスト置換が正当化されるわけではない。 --ただ、#if 0 ~ #endif でコメントアウトするのはネストできるので有益だと思う。でもこの記法は適切だとは思えないので、ネストできる記法を考えたい。 ** (2) -[Q] どこから作るか --[A]
タイムスタンプを変更しない
* 言語自作に関する思いを書く -(by [[K]], 2018.01.20) ** (1) -[Q] なぜインタプリタにこだわるのか?#1 --[A] インタプリタなら、実行しない部分をちゃんと書いておく必要はない。それがうれしい。 --開発中に「とりあえずここまでで実行してみるか」って思ったときに、「宣言されていない関数を呼び出している部分があります」っていうエラーが出てくるのが本当にうっとうしい。「そこはどうせテスト実行しない部分なんだからどうでもいいだろ」って思うのに・・・。 --それでダミー関数を置いたりするわけだけど、それが効率のいいやり方だとは到底思えない。 --他にも宣言していない変数を参照しているとか、そういうエラーもうっとうしい。だからそこは今回は実行しない部分だからどうでもいいって言っているのに! -[Q] なぜインタプリタにこだわるのか?#2 --[A] インタプリタなら、eval命令を容易に実現できる。つまりプログラムでプログラムを生成し、それを直ちに実行できる。実行中に自分自身に関数や構造体を追加したり削除できたらどんなにいいだろう。 --いまでもC言語などでは機械語を出力して実行することはできる(JITコンパイラは基本的にそうやっている)。でも機械語を出力するので機種依存がある。機械語を出力するので、難易度が高い。EssenならEssenのプログラムを出力するだけでJITコンパイルをできるようにしてやろうではないか。 -[Q] プリプロセッサは排除したいのはなぜか? --[A] ただのテキスト置換で言語の機能を補うというのは、うまいやり方ではない。#defineで関数もどきを書くときに、演算子の優先順位を何とかするために引数をカッコでくくるとか、バッドノウハウにしかみえない。そんなのが正解なんだろうか。 --同じことがしたいのならinline関数で代用できるべきだし、#defineでやったほうが効率がいいのなら、それはもはやinline関数のほうを改良すべきなのであって、プリプロセッサによるテキスト置換が正当化されるわけではない。 --ただ、#if 0 ~ #endif でコメントアウトするのはネストできるので有益だと思う。でもこの記法は適切だとは思えないので、ネストできる記法を考えたい。 ** (2) -[Q] どこから作るか --[A]
テキスト整形のルールを表示する