はじめに
設定に Spring 設定ファイル で XML ファイルを使用すると、実際に Spring で対応するコードを実行できるようになります。たとえば:
要素を使用すると、実際には Spring でパラメータまたはパラメータ化されたコードを実行できます。コンストラクター は
要素を使用しており、これにより Spring は実際に setter メソッドを 1 回実行できます
しかし、Java プログラムには、ゲッター メソッドの呼び出し、通常のメソッドの呼び出し、フィールドのフィールドへのアクセスなど、他の種類のステートメントも含まれる場合があります。 Spring はそのようなステートメントに対応する設定構文も提供します:
getter メソッドを呼び出す: PropertyPathFactoryBean
を使用してクラスまたはオブジェクトの Field 値を呼び出す: FiledRetrievingFactoryBean
を使用する通常のメソッドを呼び出す場合: MethodInvokingFactoryBean
を使用して、他のBeanのpropertyvalue
PropertyPathを注入します。FactoryBeanは、対象Beanのプロパティ値(実際にはgetterメソッドを呼び出して返される値)を取得するために使用されます。取得した値を他のBeanに注入することもできます。また、新しいBeanを直接定義することもできます。次の設定ファイルを見てください:
<bean id="person" class="com.abc.Person"> <property name="age" value="30" /> <property name="son"> <!-- 使用嵌套Bean定义属性值 --> <bean class="com.abc.service.Son"> <property name="age" value="11" /> </bean> </property> </bean> <bean id="son2" class="com.abc.service.Son"> <!-- age属性不是直接注入,而是将person中的son的age属性赋值给son2的age属性 --> <property name="age"> <!-- 注意这里使用的是PropertyPathFactoryBean --> <bean id="person.son.age" class="org.springframework.beans.factory.config.PropertyPathFactoryBean" /> </property> </bean>
Person クラスと Son クラスの属性は、設定ファイルから確認できますが、現在は提供されていません。主なプログラムは以下の通りです:
public class Test { public static void main(String args[]) { ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml"); System.out.println("age=" + ac.getBean("son2", Son.class).getAge()); } }
出力結果:
age=11
Beanインスタンスのプロパティ値を他のBeanに注入するだけでなく、Beanインスタンスのプロパティ値を直接Beanインスタンスとして定義することもできます。これも PropertyPathFactoryBean を通じて行われます。このセクションを上記の設定ファイルに追加します。
<bean id="son1" class="org.springframework.beans.factory.config.PropertyPathFactoryBean"> <!-- 确定目标Bean,表明son1来自哪个Bean的组件 --> <property name="targetBeanName" value="person" /> <!-- 确定属性,表明son1来自目标Bean的哪个属性 --> <property name="propertyPath" value="son" /> </bean>
上記の Test クラスを実行し、son2 を Son1 に置き換えます。結果は同じです。
他のBeanのField値を注入する
FieldRetrievingFactoryBeanクラスを通じて、他のBeanのField値を他のBeanに注入したり、新しいBeanを直接定義したりできます。以下は設定の一部です:
<bean id="son" class="com.abc.service.Son"> <property name="age"> <bean id="java.sql.connection.TRANSACTION_SERIALIZABLE" class="org.springframework.beans.factory.config.FieldRetrievingFactoryBean" /> </property> </bean>
メインのテスト プログラムは上で定義したものと似ていますが、ここでは提供されません。 実行結果は次のとおりです:
age=8
この設定では、son オブジェクトの age 値は次のとおりです。 java.sql.Connection.TRANSACTION_SERIALIZABLE 値と等しい。上記の定義では、FieldRetrievingFactoryBean ファクトリ Bean を定義するときに、指定される ID は Bean インスタンスの一意の識別子ではなく、指定された Field の式 (取り出される値) になります。
注: フィールドは 静的 または非晶質のいずれかになります。上記の構成スニペットで指定された Field 式は静的な Field 値であるため、クラス名を通じて直接アクセスできます。 Field 値が非静的である場合、コンテナ内にすでに存在する Bean を通じてアクセスする必要があります。つまり、Field 式の最初のフレーズはコンテナ内にすでに存在する Bean である必要があります。
フィールド値は Bean インスタンスとして定義することもできます。たとえば、次の段落を設定ファイルに追加します。
<bean id="age" class="org.springframework.beans.factory.config.FieldRetrievingFactoryBean"> <!-- targetClass指定Field所在的目标类 --> <property name="targetClass" value="java.sql.Connection" /> <!-- targetField指定Field名 --> <property name="targetField" value="TRANSACTION_SERIALIZABLE" /> </bean>
次の出力をメイン プログラムに追加します。
System.out.println("age=" + ac.getBean("age"));
実行結果は上記と同じです。
FieldRetrievingFactoryBean を使用して Field 値を取得する場合は、次の 2 つの属性を指定する必要があります:
targetClass または targetObject: それぞれ、Field 値が配置されるターゲットまたはターゲット オブジェクトを指定するために使用されます。取得する必要があるフィールドが静的である場合は、targetClass を使用してターゲットを指定し、フィールドが非静的である場合は、targetObject を使用してターゲット オブジェクトを指定します
-
targetField: ターゲット クラスまたはターゲット オブジェクトのフィールド名を指定します
フィールドが静的フィールドの場合、より簡潔な書き方があります:
<bean id="age" class="org.springframework.beans.factory.config.FieldRetrievingFactoryBean"> <!-- value指定哪个类的哪个静态域值 --> <property name="staticField" value="java.sql.Connection.TRANSACTION_SERIALIZABLE" /> </bean>
他のBeanのメソッド戻り値を注入します
MethodInvokingFactoryBeanファクトリBeanを通じて、ターゲットメソッドの戻り値を次のように注入できます。 Beanの属性値。このファクトリ Bean は、指定されたメソッドの戻り値を取得するために使用されます。この値は、静的メソッドまたはインスタンス メソッドのいずれかです。この値は、指定された Bean インスタンスの指定された属性に注入することも、メソッドとして直接定義することもできます。 Bean インスタンス。例を見てください:
<bean id="valueGenerator" class="com.abc.util.ValueGenerator" /> <bean id="son1" class="com.abc.service.Son"> <property name="age"> <!-- 获取方法返回值:调用valueGenerator的getValue方法 --> <bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="targetObject" ref="valueGenerator" /> <property name="targetMethod" value="getValue" /> </bean> </property> </bean>
以下は ValueGenerator です:
public class ValueGenerator { public int getValue() { return 2; } public static int getStaticValue () { return 3;} }
テスト プログラムは引き続き Son1 の age の値を出力します。コードは省略されています。結果は次のとおりです:
age=2
静的メソッドを呼び出したい場合メソッドの設定を次のように変更します:
<bean id="son1" class="com.abc.service.Son"> <property name="age"> <!-- 获取方法返回值:调用valueGenerator的getStaticValue方法 --> <bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="targetClass" value="com.abc.util.ValueGenerator" /> <property name="targetMethod" value="getStaticValue" /> </bean> </property> </bean>
テスト結果は次のとおりです:
age=3
Java は オーバーロード をサポートしているため、メソッド名を指定するだけでは呼び出しが成功する理由を決定できません。上記の設定は、ValueGenerator の両方のメソッドにパラメーターがないためです。メソッドにパラメータがある場合、どのように設定すればよいですか?次の内容を設定ファイルに追加します。
<bean id="sysProps" class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="targetClass" value="java.lang.System" /> <property name="targetMethod" value="getProperties" /> <bean> <bean id="javaVersion" class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <!-- 指向上面的sysProps Bean --> <property name="targetObject" value="sysProps" /> <property name="targetMethod" value="getProperty" /> <!-- 这里配置参数 --> <property name="arguments"> <!-- 使用list元素列出调用方法的多个参数 --> <list> <value>java.version</value> </list> </property> <bean>
上記の例は、「java.version」をパラメータとして java.lang.System の getProperty メソッドを呼び出すことと同等であり、戻り値は javaVersion という名前の Bean を作成します。これは次と同等です:
javaVersion = java.lang.System.getProperty("java.version");
前の記事の Field と同じですが、呼び出されるメソッドが静的メソッドの場合、より簡潔なメソッドがあります:
<bean id="myBean" class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <!-- 使用staticMethod属性,直接指定目标类的目标方法 --> <property name="staticMethod" value="com.abc.util.ValueGenerator.getStaticValue" /> </bean>
以上がJava Springの未知のインジェクションメソッドを詳しく解説の詳細内容です。詳細については、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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









