挑戦
先週末、私は Clojure が既存の Java エコシステムとどのように対話できるかをさらに調査することにしました。その課題は単純でした。
Quarkus フレームワークをベースとして使用して、Clojure で単純な Web フレームワークを作成します。
敷地:
- Quarkus は、ルートがいくつ存在するかさえも、ルートごとに何が実行されるのかを知りません。
- Clojure を使用してルートとハンドラーをできるだけ簡単に作成できるはずです。
(defn send-hello-world [] "Hello World") (defn routes [] [{:method "GET" :path "/hello" :handler send-hello-world}])
いくつかの定義:
- Quarkus: Quarkus は、Java 仮想マシン (JVM) およびネイティブ コンパイル用に作成されたフルスタックの Kubernetes ネイティブ Java フレームワークであり、特にコンテナー向けに Java を最適化します。
- Clojure: 動的な汎用プログラミング言語
ステップ 1: Quarkus アプリの作成
Quarkus でアプリを起動するのは非常に簡単です。このチュートリアルに従ってください。最後のコマンドが quarkus create && cd code-with-quarkus であることがわかります。その後、次のコマンドで code-with-quarkus フォルダーを開くことができます。お気に入りの IDE で、コマンドによって Quarkus アプリの基本構造が作成され、quarkus dev
で実行できます。ステップ 2: プロジェクトが clj ファイルを認識できるようにする
ターゲット フォルダー (コンパイルされたアプリが含まれるフォルダー) に .clj ファイルを含めるように Quarkus を設定する必要があります。これを行うには、
内の pom.xml にこの設定を追加します。
<resources> <resource> <directory>/</directory> <includes> <include>*.clj</include> </includes> </resource> </resources>
ステップ 3: Clojure ファイルを作成する
前に述べたように、フォルダー main の同じ場所に、ルートを宣言するための 1 つの構造体を定義しました。次に、以下のコードを含む core というファイルを含む quarkus_clj という名前のフォルダーを作成しました。
(ns quarkus-clj.core) (defn send-hello-world [] "Hello World") (defn routes [] [{:method "GET" :path "/hello" :handler send-hello-world}])
ステップ 4: Quarkus が Clojure プログラムを処理できるようにする
ここで魔法が起こる??!
まず、Quarkus アプリ内に Clojure をインストールする必要があります。これを行うには、pom.xml
に依存関係を追加します。
<dependency> <groupid>org.clojure</groupid> <artifactid>clojure</artifactid> <version>1.11.1</version> </dependency>
これで、ファイル GreetingResource.java とそのテストを削除できます。同じ場所に、Starting.java
ファイルを作成します。どのように機能するかを説明するコメントをいくつか書きます
@ApplicationScoped public class Starting { //Setup app routes public void setupRouter(@Observes Router router) { // Load Clojure core; IFn require = Clojure.var("clojure.core", "require"); // Load quarkus-clj.core namespace require.invoke(Clojure.read("quarkus-clj.core")); // Load the route list function IFn routesFn = Clojure.var("quarkus-clj.core", "route"); // Invoke the function with no parameters PersistentVector routesVector = (PersistentVector) routesFn.invoke(); //For each route in routes vector for (Object route : routesVector) { /**Get the route map, example {:method "GET" :path "/hello" :handler send-hello-world} */ PersistentArrayMap routeMap = (PersistentArrayMap) route; //Get :path value String path = (String) routeMap.valAt(Clojure.read(":path")); //Get :handler function IFn handlerRoute = (IFn) routeMap.valAt(Clojure.read(":handler")); //Get :method value String method = (String) routeMap.valAt(Clojure.read(":method")); //Create a handler to exec handler function Handler<routingcontext> handlerFn = (RoutingContext context) -> { String result = (String) handlerRoute.invoke(); context.response().end(result); }; //Config the route in quarkus router.route(HttpMethod.valueOf(method), path).handler(handlerFn); } } } </routingcontext>
これで、「quarkus dev」を実行するだけで、宣言されたルートを開いて結果を確認できます。
結論
これは、Quarkus アプリ内で Clojure を使用して動的ルートを作成する方法の簡単な例でした。わずか数ステップで 2 つのエコシステムを接続し、基本的なルーティング システムをセットアップしました。自由にこの基盤を拡張し、Clojure と Quarkus を使用して他の可能性を探索してください!
以上が実際の例を使用して Java から Clojure を呼び出す (Clojure Quarkus)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

新しいテクノロジーは、両方の脅威をもたらし、Javaのプラットフォームの独立性を高めます。 1)Dockerなどのクラウドコンピューティングとコンテナ化テクノロジーは、Javaのプラットフォームの独立性を強化しますが、さまざまなクラウド環境に適応するために最適化する必要があります。 2)WebAssemblyは、Graalvmを介してJavaコードをコンパイルし、プラットフォームの独立性を拡張しますが、パフォーマンスのために他の言語と競合する必要があります。

JVMの実装が異なると、プラットフォームの独立性が得られますが、パフォーマンスはわずかに異なります。 1。OracleHotspotとOpenJDKJVMは、プラットフォームの独立性で同様に機能しますが、OpenJDKは追加の構成が必要になる場合があります。 2。IBMJ9JVMは、特定のオペレーティングシステムで最適化を実行します。 3. Graalvmは複数の言語をサポートし、追加の構成が必要です。 4。AzulzingJVMには、特定のプラットフォーム調整が必要です。

プラットフォームの独立性により、開発コストが削減され、複数のオペレーティングシステムで同じコードセットを実行することで開発時間を短縮します。具体的には、次のように表示されます。1。開発時間を短縮すると、1セットのコードのみが必要です。 2。メンテナンスコストを削減し、テストプロセスを統合します。 3.展開プロセスを簡素化するための迅速な反復とチームコラボレーション。

java'splatformentedencefacilitatesecodereusebyAllowingbyTeCodeCodeCodeCodeTorunonAnyPlatformm.1)DevelopersConcodeCodeOnceOnceOnconconsentEntentEntEntEntEntEntentPlatforms.2)維持化されたアスカデドは、NoeedReadedoesではありません

Javaアプリケーションのプラットフォーム固有の問題を解決するには、次の手順を実行できます。1。Javaのシステムクラスを使用して、システムプロパティを表示して実行中の環境を理解します。 2。ファイルクラスまたはjava.nio.fileパッケージを使用して、ファイルパスを処理します。 3。オペレーティングシステムの条件に応じてローカルライブラリをロードします。 4. VisualVMまたはJProfilerを使用して、クロスプラットフォームのパフォーマンスを最適化します。 5.テスト環境が、Dockerコンテナ化を通じて生産環境と一致していることを確認してください。 6. githubactionsを使用して、複数のプラットフォームで自動テストを実行します。これらの方法は、Javaアプリケーションでプラットフォーム固有の問題を効果的に解決するのに役立ちます。

クラスローダーは、統一されたクラスファイル形式、動的読み込み、親代表団モデル、プラットフォーム非依存バイトコードを通じて、さまざまなプラットフォーム上のJavaプログラムの一貫性と互換性を保証し、プラットフォームの独立性を実現します。

Javaコンパイラによって生成されたコードはプラットフォームに依存しませんが、最終的に実行されるコードはプラットフォーム固有です。 1。Javaソースコードは、プラットフォームに依存しないバイトコードにコンパイルされます。 2。JVMは、特定のプラットフォームのバイトコードをマシンコードに変換し、クロスプラットフォーム操作を保証しますが、パフォーマンスは異なる場合があります。

マルチスレッドは、プログラムの応答性とリソースの利用を改善し、複雑な同時タスクを処理できるため、最新のプログラミングで重要です。 JVMは、スレッドマッピング、スケジューリングメカニズム、同期ロックメカニズムを介して、異なるオペレーティングシステム上のマルチスレッドの一貫性と効率を保証します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

メモ帳++7.3.1
使いやすく無料のコードエディター

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

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
