※ 引述《dragoncfe168 (梅長蘇)》之銘言:
: 請問一下
: 為何直譯器將source code轉譯成機器碼,
: 不會產生不同電腦的機器語言不同 而無法執行的問題???
: 反觀同樣把source code轉譯成機器碼的編譯器
: 卻會有此類問題呢???
呃,我覺得你沒有搞清楚一件事,原始碼、中間碼、機器碼的差異。
首先,編譯器的目的,不是轉成機器碼用的。
編譯器的目的,是把語言 A 的原始碼,轉成語言 B 的原始碼用的。
例如 LLVM 或者是 GCC,它們把 C/C++ 轉過後,不是直接變成執行檔,
而是先變成一個特殊語言的中間碼 (IR),再由後端(backend)機制,轉成執行檔。
而執行檔,也可以說是一種機器碼。
若是語言 B 就是組語,當然你也可以當作是一種轉機器碼。
而直譯器的目的,是用來直接執行的。
換句話說,原始檔並沒有經過轉換!沒有 xxxx.a -> xxxx.b -> xxxx.exe
這種過程,而是 xxxx.a 直接餵進直譯器,由直譯器幫你執行。
以 Java 為例,XXXX.java -> XXXX.class 這過程,的確可以說是編譯。
而從概念性的角度來看,JVM 執行 XXXX.class 這過程,可以說是直譯。
這若牽涉到內部 JIT 的運作,則 JVM 亦有編譯機制在裡頭,但這更深了,
不在討論範圍。