【iOS版アプリ】不具合のお知らせ

デフォルトのwin10でプログラム言語(主にインプリンタ言語phpやpythonなど)は、exe化してもファイルが壊れているという警告を受けました。
インプリンタ言語はインスト―ルしないと動かないのでしょうか?
または、osがサポートしている言語以外はインストールが必要なのでしょうか?

gooドクター

A 回答 (4件)

☓ インプリンタ言語はインスト―ルしないと動かない


○ 要仮想マシンの言語はインストールしないと動かない

ハッキリ言っておきますが、コンパイラ言語、インタプリタ言語、と言う区分けは間違いです。
間違い、って言うのが言い過ぎなら、少なくとも現状には合わない。
例えば、Javaは一般にコンパイラ型言語だと思われていますが、かと言ってJava仮想マシン(JVM)が無いといくらexeファイルがあっても動かないのは良く知られたトコです。
Pythonも場合によっては内部的にはファイルはコンパイルされます。ただし、本体、つまり、Python仮想マシンがインストールされないと動かない、と言うのはJavaと同じです。
この様に、実は現状では「コンパイラ言語」「インタプリタ言語」と言う区分けは全くの無意味なのです。
好意的に解釈すれば

「仮想マシンの動作原理そのものがインタプリタである」

と言う言い方は出来ますが、それ以上の意味はないですね。
あるいは、

「コンパイルされたファイルがネイティブコードだ、と言う前提がないと動かない」

と言ってもいいでしょう(JavaやPython等の仮想マシン向けのコンパイル済みファイルは通称「バイトコード」等と呼ばれたりします)。

> osがサポートしている言語以外はインストールが必要

OSがサポートしている、のではなくって、コンパイラがネイティブコード(例えばPC向けだとIntel CPU用のマシン語等)を吐かなければ、適する「仮想マシン」のインストールが必要だ、と言う事です。

ただ、僕も#1氏と同じく、PHPはピュアなインタプリタだったと思います。だからexeファイル作る手段って無かったんじゃないかな・・・・・?分からんけど。
元々PHPはホンマに特定の用途・・・つまり、Webサイト絡みで使用されるのを前提としてるので、そもそも単独で実行されるのを念頭に置いて開発されてこなかった、ってのが一つの理由。だからWindowsでexeファイルに出来なくても用途的には誰も困らなかった、んですよね。
もう一つの理由は、そもそもサーバーサイドで走らせる目的の言語だった、って事ですよね。JavaScriptのようにクライアントサイドで走らせる、って前提で設計されていない。で、想定されてるサーバーが元々UNIX系だ、って事も前提で、やっぱりWindowsでexeファイルとして実行させる意図がそもそも無かった、って事ですよね。
(例えばWikipediaで使われてるMediaWikiはPHPで書かれてますが、Wikipediaを見る/読む側のパソコンにPHPがインストールされてないのに見たり読んだり書いたり出来るのは、PHPはUNIXサーバー側で動いてる、からであって、そういうカンジでそもそも「クライアントPC側で動かすのを前提にしてない」のです。)

※: 処理系依存の話であるが、例えば一般にインタプリタだと思われてるANSI Common Lisp等は処理系によってはソースコードをコンパイルして「単独実行可能」のコンパイル済みファイルを生成したりする。こういう単独実行可能のコンパイル済みファイルを「スタンドアローン」等と呼称したりする。
が、Python等にこれを要求するのはかなり難しい。
特定のANSI Common Lisp処理系の場合、プログラマが書いたソースコードをコンパイルする他、Common Lispインタプリタで「そのプログラムに必要だと思われるライブラリ」を別途コンパイルしてリンク、また、インタプリタの部分の「最小限の部分」、コア等と呼んだりするが、こいつも分離してコンパイルしてリンクする、と言うなかなかメンド臭い事をやったりしてる。
つまり、ユーザー側から見るとそのANSI Common Lisp処理系をインストールしなくても、exeファイルをダブルクリックすればフツーのC++で書かれたプログラムみたいに起動するように見えるが、中身は小型インタプリタと特定の抜粋されたライブラリとの混合体だったりする。
このように、いわゆるインタプリタ型言語から「スタンドアロンの」ファイル実行形式を得るのは難しい。
ただし、いわゆるコンパイル型言語でも真の意味での「スタンドアロンの」実行ファイルを作るのも難しくなっている。たまに見かけるエラーメッセージ「dllがありません」と言うのは依存するライブラリがある、って事で、上記のANSI Common Lispの例を考えるとその背後に隠された「メンド臭さ」は想像が付きやすいだろう。
また、Windowsの場合、C#って言語が上記のJavaのようなモノで、「OSがサポートしてる」と言うより「WindowsでC#用の仮想マシンがデフォルトで提供されている」と言った方が良く、従ってユーザーはC#用の仮想マシンを別途インストールする必要はないが、結果、実はこれで作成されてるソフトウェアが真の意味で「スタンドアロン」なのか?と言うと大幅に違う。実はやってる事はANSI Common Lispと同じで、結果C#用の仮想マシンから真の意味での「実行形式」が切り離せないのは技術的にはPython等と全く同じである。
    • good
    • 0
この回答へのお礼

こんなに詳しく。
ありがとうございます。

お礼日時:2021/07/25 15:06

ちょっと調べてみましたが


phpも中間コードにまでコンパイルされてキャッシュされ
VM上で実行されるようですね。

https://www.webprofessional.jp/how-php-executes- …

純粋なインタープリターはもう殆んど
残ってないのかも。
    • good
    • 0

pythonの方はpyInstallerとかの話かな?


仲の悪いパッケージ(matplotlib)とかがあって完全にはexe化
出来ないみたいですね。

pyInstallerも結局pythonの実行環境をまるごと
exeに固めて持ち運んでいるだけです。

phpはexe化したこと無いので良く知らんです。

それから、pythonはコンパイルして実行する言語ですが
コンパイルする場合でもランタイムやVMが必要なものは
実行環境が必要です。

Delphiみたいに完全にスタンドアロンなexeを作れる言語は
寧ろ珍しいですね。
    • good
    • 0

>>インプリンタ言語はインスト―ルしないと動かないのでしょうか?



通常、インタプリタ言語を使うには、インストールする必要があります。

>>osがサポートしている言語以外はインストールが必要なのでしょうか?

そうですね。

なお、私は、phpのexe化を見たことありません。
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています

gooドクター

このQ&Aを見た人がよく見るQ&A

このカテゴリの人気Q&Aランキング