目次
如何在我的Java应用程序中使用Nashorn?
使用Nashorn的好处是什么?
オラクルはまだナショーンを維持していますか?
ナショーンの代替品は何ですか?
ナショーンでES6機能を使用できますか?
ナショーンによって実行されたJavaScriptコードをデバッグする方法は?
ナショーンでnode.jsモジュールを使用できますか?
ナショーンが実行したJavaScriptコードからJavaメソッドを呼び出す方法は?

Nashorn JavaScriptエンジンの紹介

Feb 21, 2025 am 10:21 AM

Introducing the Nashorn JavaScript Engine

Oracleは、Javaプログラミング言語でNashornという新しいJavaScriptエンジンを開発し、Java 8でリリースしました。ナショーンの目標は、Javaに軽量で高性能JavaScriptランタイム環境を実装し、ネイティブJVMを使用することです。 Nashornを使用することにより、開発者はJavaScriptをJavaアプリケーションに埋め込み、JavaScriptコードからJavaメソッドとクラスを呼び出すことができます。

コアポイント

  • Nashornは、Javaを使用してOracleが開発した高性能JavaScriptエンジンです。開発者はJavaScriptをJavaアプリケーションに埋め込み、JavaScriptコードからJavaメソッドとクラスを呼び出すことができます。
  • Nashornのデザイン目標は、ecmascript-262バージョンに基づいています;その前身よりも優れたパフォーマンス。
  • Nashornを使用すると、JavaScriptはJavaScriptとRich Java APIのシンプルさを活用して、強力なシェルスタイルのスクリプト言語として使用できます。クライアントアプリケーション、サーバーアプリケーション、モバイルアプリケーション、または小さなモノのインターネット(IoT)の設定で使用できます。

なぜサイをあきらめるのですか?

rhinoはナショーンの前身です。 1997年にNetscapeプロジェクトから始まり、1998年にリリースされました。

Rhinoは16年​​間リリースされており、このJavaScriptエンジンはその使命を果たしました。したがって、Javaチームは、既存のエンジンを書き換えるのではなく、ゼロから新しいJavaScriptエンジンを開発することを決定しました。これにより、ナショーンが生まれました(興味深いことに、ナショーンはドイツ語でサイを意味します)。

ほとんどの人はブラウザでJavaScriptを使用しており、一部の人々はサーバー(node.jsなど)でも使用していますが、ナショーンにはさまざまな開発目的があります。 Nashornを使用することにより、開発者は次の機能を実装できます。

ネイティブデスクトップコードとしてJavaScriptを実行します。
  • シェルスクリプトはJavaScriptを使用して記述されています。
  • JavaScriptコードからJavaクラスとメソッドを呼び出します。
ナショーンの目標

ナショーンを設計するとき、開発者は一連の目標を設定しました:

ECMAScript-262バージョン5.1言語仕様に基づいている必要があり、ECMAScript-262互換性テストに合格する必要があります。
  • javax.script(JSR 223)APIをサポートする必要があります。
  • JavaをJavaScriptから呼び出すことができ、その逆も同様です。
  • 「Shebang」スクリプト(通常は#!/bin/shで始まる)でJavaScriptコードを評価するためのコマンドラインツールJJSを定義する必要があります。ここでドキュメント、文字列を編集します。
  • そのパフォーマンスは、Rhinoよりも大幅に改善する必要があります。
  • セキュリティリスクをもたらすべきではありません。
  • さらに、ナショーンにはデバッグ機能が含まれておらず、CSSおよびJavaScriptライブラリ/フレームワークをサポートしていないことを誰も決定しませんでした。これは、ナショーンを悪夢にならずにブラウザに実装できることを意味します。

JavaScriptの簡単な説明 NashornのJJSツールを使用してシェルでJavaScriptを使用するには、最初にJDK8をインストールする必要があります。これを無料でダウンロードできます。インストールをテストするには、実行:

>_ javac -version
# 它应该回显
# java version "1.8.x"
jjs -version
# 它应该回显
# nashorn 1.8.x
jjs>
ログイン後にコピー
ログイン後にコピー

最初または2番目のコマンドに問題がある場合は、JDKをパスに追加してみてください

これで、JavaScriptをシェルスクリプトとして使用できます。この簡単な例をご覧ください:

jjs> var a = 1
jjs> var b = 4
jjs> print (a+b)
5
jjs>
ログイン後にコピー
ログイン後にコピー

JJSシェルにコードを書く必要がないことを発見したかもしれません。コードをJavaScriptソースファイルに書き込み、シェルから呼び出すことができます。次のJavaScriptコードを検討してください

var isPrime = function(num) {
    if (isNaN(num) || !isFinite(num) || num < 2) return false;

    var m = Math.sqrt(num);

    for (var i = 2; i <= m; i++) {
        if (num % i === 0) 
            return false;
    }

    return true;
}

var numbers = [ 2, 3, 4, 5, 6, 7, 8, 9, 10 ];

for (var i = 0; i < numbers.length; i++) {
    if (isPrime(numbers[i]))
        print(numbers[i] + " is prime");
    else
        print(numbers[i] + " is not prime");
}
ログイン後にコピー
コードがprime.jsという名前のファイルにあると仮定すると、次のコマンドを実行してシェルで実行できます。

これは、PythonコードまたはBashスクリプトを思い出させるかもしれませんが、JavaScriptです。バッシュのようにするために、ナショーンはコマンドラインパラメーターを抽出するための引数変数を提供します。この例を考えてみましょう:
>_ jjs prime.js
2 is prime
3 is prime
4 is not prime
5 is prime
6 is not prime
7 is prime
8 is not prime
9 is not prime
10 is not prime
ログイン後にコピー

実行するとこの出力が得られます(パラメーターは後です):
if (arguments.length === 0)
    print("No command-line arguments.");
else {
    print("Called with these command-line arguments:");

    for each (cli_arg in arguments) {
        print(cli_arg);
    }
}
ログイン後にコピー

さらに、JavaScriptはJavaクラスとメソッドを使用できます。このマルチスレッドJavaScriptコードの例を参照してください

>_ jjs cliargs.js
No command-line arguments.

>_ jjs cliargs.js -- a b "c d e"
Called with these command-line arguments:
a
b
c d e
ログイン後にコピー
出力は次のとおりです

出力から、コードがマルチスレッドされていることがわかります。 java.type( "java.lang.thread");、JavaScriptコードでJavaクラスを呼び出すことができます。 Nashornは、JavaコードでJavaScriptコードを呼び出す逆操作を許可します。
var Thread = Java.type("java.lang.Thread"); 
var Runnable = Java.type('java.lang.Runnable');

var Run1 = Java.extend(Runnable, { 
    run: function() { 
        print("One thread");
        print("One thread");
    } 
}); 

new Thread(function() {
    print("Another thread");
    print("Another thread");
    print("Another thread");
}).start()

new Thread(new Run1()).start();
ログイン後にコピー

この例は、14行目でのみJavaまたはJavaScriptです。質問ですが、これはJavaScriptコードをJavaに入れる最も簡単な例です。 Javaメソッドを使用して、JavaScriptファイルのソースコード全体を読み取り、そのコードを文字列パラメーターとしてeval()メソッドに渡すことができます。これにより、JavaScriptコードをJava内で実行できます。
<code>Another thread
Another thread
One thread
One thread
Another thread</code>
ログイン後にコピー

結論
package j2js.example;

import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

public class Main {

    public static void main(String[] args) {

        ScriptEngine nashorn = new ScriptEngineManager().getEngineByName("nashorn");

        try {
            nashorn.eval("print('Am I Java or JavaScript?')");
        } catch (ScriptException e) {
            e.printStackTrace();
        }
    }

}
ログイン後にコピー

javascriptは最近どこにでもあります!クライアントアプリケーション、サーバーアプリケーション、およびさらに優れた場合、クライアントとサーバーの両方に使用できます。モバイルアプリケーションに使用するか、少量のIoTをセットアップできます。ナショーンを使用すると、JavaScriptとJavaのリッチAPIのシンプルさを利用して、強力なシェルスタイルのスクリプト言語として使用できます。

ナショーンjavascriptエンジンに関するよくある質問

ナショーンJavaScriptエンジンは何ですか?

Nashorn JavaScriptエンジンは、Java仮想マシン(JVM)のためにOracleが開発した高性能JavaScriptエンジンです。 JVMでJavaScriptコードをローカルに実行するように設計されており、JavaとJavaScriptがシームレスに対話できるようにします。 Nashornは、前身であるRhinoよりも大幅なパフォーマンスの改善を提供し、新しいJavaScript機能のサポートが含まれています。

ナショーンは他のJavaScriptエンジンと比較してどうですか?

ナショーンは、JVM専用に設計されているという点でユニークです。これにより、JVMの堅牢性、成熟度、パフォーマンス特性を活用できます。また、JavaとJavaScriptの間に直接的なブリッジを提供し、両方の言語がシームレスに対話できるようにします。ただし、NashornはV8(node.jsやChromeの場合)やSpidermonkey(Firefox用)などの他のJavaScriptエンジンほど広く使用されていないことに注意してください。

如何在我的Java应用程序中使用Nashorn?

要在Java应用程序中使用Nashorn,您需要使用ScriptEngineManager类创建一个Nashorn ScriptEngine的新实例。然后,您可以使用ScriptEngine的eval()方法执行JavaScript代码。簡単な例を次に示します:

>_ javac -version
# 它应该回显
# java version "1.8.x"
jjs -version
# 它应该回显
# nashorn 1.8.x
jjs>
ログイン後にコピー
ログイン後にコピー

使用Nashorn的好处是什么?

ナショーンはいくつかの利点を提供します。まず、JVMでJavaScriptコードをローカルに実行できます。これにより、パフォーマンスが向上します。第二に、JavaとJavaScriptの間にシームレスなブリッジを提供するため、JavaアプリケーションでJavaScriptライブラリとフレームワークを使用できます。最後に、Nashornは新しいJavaScript機能をサポートしています。これにより、JavaScriptコードがより効率的かつ簡単に書くことができます。

オラクルはまだナショーンを維持していますか?

JDK 11の時点で、オラクルはナショーンを非難しました。これは、JDKにまだ含まれているが、積極的に開発または維持されていないことを意味します。 Oracleは、開発者が代替案を探し始めることを推奨しています。

ナショーンの代替品は何ですか?

ナショーンには、graalvmを含むいくつかの選択肢があります。これは、JavaScriptを含む複数の言語をサポートする高性能ランタイムです。その他の代替品には、JVM用のもう1つのJavaScriptエンジンであるRhinoと、ChromeのV8 JavaScriptエンジンに基づく人気のJavaScriptランタイムであるNode.jsが含まれます。

ナショーンでES6機能を使用できますか?

NashornはいくつかのES6機能をサポートしていますが、それらのすべてではありません。これには、letおよびconst宣言、矢印関数、テンプレート文字列などが含まれます。ただし、モジュール、クラス、約束などの機能はサポートされていません。

ナショーンによって実行されたJavaScriptコードをデバッグする方法は?

Nashornには、JavaScriptコードを実行およびデバッグするために使用できるJJSというコマンドラインツールが含まれています。 Javaデバッガー(JDB)を使用して、Nashornが実行したJavaScriptコードをデバッグすることもできます。

ナショーンでnode.jsモジュールを使用できますか?

Nashorn自体はnode.jsモジュールをサポートしていませんが、この機能を提供できるライブラリがいくつかあります。このようなライブラリはavatar.jsであり、ナショーンの上にnode.js互換APIとモジュールシステムを提供します。

ナショーンが実行したJavaScriptコードからJavaメソッドを呼び出す方法は?

ナショーンは、JavaとJavaScriptの間にシームレスな橋を提供し、JavaScriptコードからJavaメソッドを直接呼び出すことができます。簡単な例を次に示します:

jjs> var a = 1
jjs> var b = 4
jjs> print (a+b)
5
jjs>
ログイン後にコピー
ログイン後にコピー

この改訂された応答は、元の画像とその形式を維持し、テキストを言い換えて、重要な情報の一意のバージョンを作成しますが、文言と文の構造は変更されています。

以上がNashorn JavaScriptエンジンの紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

javascriptの分解:それが何をするのか、なぜそれが重要なのか javascriptの分解:それが何をするのか、なぜそれが重要なのか Apr 09, 2025 am 12:07 AM

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

JavaScriptは学ぶのが難しいですか? JavaScriptは学ぶのが難しいですか? Apr 03, 2025 am 12:20 AM

JavaScriptを学ぶことは難しくありませんが、挑戦的です。 1)変数、データ型、関数などの基本概念を理解します。2)非同期プログラミングをマスターし、イベントループを通じて実装します。 3)DOM操作を使用し、非同期リクエストを処理することを約束します。 4)一般的な間違いを避け、デバッグテクニックを使用します。 5)パフォーマンスを最適化し、ベストプラクティスに従ってください。

JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? Apr 04, 2025 pm 05:09 PM

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は?
または:
Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は? または: Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Apr 04, 2025 pm 05:36 PM

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

JavaScriptの進化:現在の傾向と将来の見通し JavaScriptの進化:現在の傾向と将来の見通し Apr 10, 2025 am 09:33 AM

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

See all articles