Java リフレクション リフレクションの基本
1. リフレクション
リフレクション: JAVA リフレクション メカニズムは、どのクラスでも、このクラスのすべてのプロパティとメソッドを知ることができます。どのオブジェクトでも、そのメソッドとプロパティを呼び出すことができます。動的に情報を取得し、オブジェクトのメソッドを動的に呼び出す機能をJava言語のリフレクション機構と呼びます。
クラスを分析したい場合は、まずクラスのバイトコード ファイル オブジェクトを取得する必要があります。この説明では Class クラスのメソッドを使用するため、最初に各バイトコード ファイルに対応する Class 型のオブジェクトを取得する必要があります。リフレクションの操作は、実際には Class オブジェクトを通じて取得されます:
*a, java.lang.reflect.Field: クラスまたはインターフェースの単一フィールドに関する情報と、それに対する動的アクセス権を提供します。反映されたフィールドは、クラス (静的) フィールドまたはインスタンス フィールドの場合があります。オペレーティングクラスのメンバー変数。
*b, java.lang.reflect.Constructor
*c, java.lang.reflect.Method: クラスを操作するメソッド。
リフレクションの基礎を学ぶ前に、インスタンスとして Person オブジェクトを作成します
package com.jalja.org.base.relfect; public class Person { private String name; int age; public String address; public Person() { } private Person(String name) { this.name = name; } Person(String name, int age) { this.name = name; this.age = age; } public Person(String name, int age, String address) { this.name = name; this.age = age; this.address = address; } public void show() { System.out.println("show"); } public void method(String s) { System.out.println("method " + s); } public String getString(String s, int i) { return s + "---" + i; } private void function() { System.out.println("function"); } @Override public String toString() { return "Person [name=" + name + ", age=" + age + ", address=" + address + "]"; } }
2. クラス
public static void getClassObject() throws ClassNotFoundException{ //方式一:Object的getClass()方法 Person person1=new Person(); Person person2=new Person(); Class c1=person1.getClass(); Class c2=person2.getClass(); System.out.println(person1==person2);//false System.out.println(c1==c2);//true 不管JVM内存中有多少个对象,对于字节码文件来说只有一份 //方式二:数据类型的静态class属性 Class c3=Person.class; System.out.println(c1==c3);//true //方式三:Class 类的静态方法 //public static Class<?> forName(String className)throws ClassNotFoundException Class c4=Class.forName("com.jalja.org.base.relfect.Person"); System.out.println(c1==c4);//true }
3. java.lang.reflect.Constructor
1. Constructor オブジェクトを取得します
//获取Class 对象所表示的类的构造方法 public static void getConstructorTest() throws Exception{ Class c4=Class.forName("com.jalja.org.base.relfect.Person"); //1、获取Class 对象所表示的类所有公共构造方法 //public Constructor<?>[] getConstructors() throws SecurityException Constructor [] cs=c4.getConstructors(); //2、获取Class 对象所表示的类所有构造方法 //public Constructor<?>[] getDeclaredConstructors() throws SecurityException Constructor[] cs2 =c4.getDeclaredConstructors(); //3、获取Class对象所表示类的指定指定公共构造方法, parameterTypes 参数是 Class 对象的一个数组 ,是指定数据类型的字节码 //public Constructor<T> getConstructor(Class<?>... parameterTypes); Constructor cs3=c4.getConstructor();//获取公共的无参构造方法的Constructor对象 //获取 该 构造函数 public Person(String name, int age, String address) Constructor cs4=c4.getConstructor(String.class,int.class,String.class); //4、获取Clss对象所表示类指定的构造范法官 parameterTypes 参数是 Class 对象的一个数组,它按声明顺序标识构造方法的形参类型的字节码。 //public Constructor<T> getDeclaredConstructor(Class<?>... parameterTypes); //获取该构造 函数 private Person(String name) 的Constructor对象 Constructor cs5=c4.getDeclaredConstructor(String.class); }
2. Constructor オブジェクトを通じて Class オブジェクトによって表されるクラスのインスタンスを作成します
4. Field オブジェクトを取得します
public static void createObject() throws Exception{ Class c4=Class.forName("com.jalja.org.base.relfect.Person"); //使用此 Constructor 对象表示的构造方法来创建该构造方法的声明类的新实例,并用指定的初始化参数初始化该实例 //public T newInstance(Object... initargs); // Person person=new Person() Constructor cs3=c4.getConstructor();//获取公共的无参构造方法的Constructor对象 Object obj=cs3.newInstance(); //Person person=new Person("jalja", 21, "北京"); Constructor cs4=c4.getConstructor(String.class,int.class,String.class); Object obj1=cs4.newInstance("jalja",21,"北京"); System.out.println(obj1);//Person [name=jalja, age=21, address=北京] //实例化一个私有的构造函数 private Person(String name) //控制java的访问检查 //public void setAccessible(boolean flag) //将此对象的 accessible 标志设置为指示的布尔值。值为 true 则指示反射的对象在使用时应该取消 Java 语言访问检查。 //值为 false 则指示反射的对象应该实施 Java 语言访问检查。 Constructor cs5=c4.getDeclaredConstructor(String.class); cs5.setAccessible(true); Object obj2=cs5.newInstance("张三丰"); System.out.println(obj2);//Person [name=张三丰, age=0, address=null] }
2. Field オブジェクトを通じて、指定されたクラス属性に値を代入します
//获取Class类的Field对象 public static void getFieldTest() throws Exception{ Class cs=Class.forName("com.jalja.org.base.relfect.Person"); //1、public Field[] getFields() throws SecurityException //获取Class 对象所表示的类或接口的所有可访问公共(public修饰的)字段 Field [] fs=cs.getFields(); //2、public Field[] getDeclaredFields() throws SecurityException // 获取Class 对象所表示的类或接口所声明的所有字段。包括公共、保护、默认(包)访问和私有字段,但不包括继承的字段 Field [] fs1=cs.getDeclaredFields(); //3、public Field getField(String name)throws NoSuchFieldException, SecurityException; //获取Class 对象所表示的类或接口的指定公共成员(public修饰)字段。name 参数是一个 String,用于指定所需字段的简称 Field fs2=cs.getField("address"); //public Field getDeclaredField(String name) throws NoSuchFieldException,SecurityException //获取 Class 对象所表示的类或接口的指定已声明字段。name 参数是一个 String,它指定所需字段的简称 Field fs3=cs.getDeclaredField("name"); System.out.println(fs3); }
5. java.lang.reflect.Method
1. Method オブジェクトを取得します
//使用 Field对象 public static void createVarValue() throws Exception{ Class cs=Class.forName("com.jalja.org.base.relfect.Person"); Object obj=cs.getConstructor().newInstance(); Field addressField=cs.getField("address"); //public void set(Object obj, Object value); //将指定对象变量上此 Field 对象表示的字段设置为指定的新值。如果底层字段的类型为基本类型,则对新值进行自动解包 //obj - 应该修改其字段的对象 value - 正被修改的 obj 的字段的新值 addressField.set(obj, "北京"); System.out.println(obj); //Person [name=null, age=0, address=北京] //对非public修饰的变量操作 Field nameField=cs.getDeclaredField("name"); //控制java的访问检查 nameField.setAccessible(true); nameField.set(obj, "张三丰"); System.out.println(obj);//Person [name=张三丰, age=0, address=北京] }
2. メソッドを通じて、指定されたクラスのメソッドを呼び出しますオブジェクト
rreee
ホットAIツール

Undress AI Tool
脱衣画像を無料で

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

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

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

JDBCトランザクションを正しく処理するには、最初に自動コミットモードをオフにし、次に複数の操作を実行し、結果に応じて最終的にコミットまたはロールバックする必要があります。 1。CONN.SETAUTOCOMMIT(FALSE)を呼び出して、トランザクションを開始します。 2。挿入や更新など、複数のSQL操作を実行します。 3。すべての操作が成功した場合はconn.commit()を呼び出し、データの一貫性を確保するために例外が発生した場合はconn.rollback()を呼び出します。同時に、リソースを使用してリソースを管理し、例外を適切に処理し、接続を密接に接続するために、接続の漏れを避けるために使用する必要があります。さらに、接続プールを使用してセーブポイントを設定して部分的なロールバックを達成し、パフォーマンスを改善するためにトランザクションを可能な限り短く保つことをお勧めします。

Java.Timeパッケージのクラスを使用して、古い日付とカレンダーのクラスを置き換えます。 2。LocalDate、LocalDateTime、LocalTimeを通じて現在の日付と時刻を取得します。 3。of()メソッドを使用して特定の日付と時刻を作成します。 4.プラス/マイナスメソッドを使用して、時間を不正に増加させて短縮します。 5. ZonedDateTimeとZoneIDを使用して、タイムゾーンを処理します。 6。DateTimeFormatterを介したフォーマットおよび解析の文字列。 7.インスタントを使用して、必要に応じて古い日付型と互換性があります。現代のJavaでの日付処理は、java.timeapiを使用することを優先する必要があります。

setupamaven/gradleprojectwithjax-rsdependencieslikejersey; 2.createarestresourceingnotationssuchas@pathand@get; 3.configuretheapplicationviaapplicationubclassorweb.xml;

依存関係の指示(di)isadesignpatternwhere objectsreceivedenciesiesedternally、setter、orfieldinoffiction.2.springframeworkusessaNnotationslike@component、@service、@autowiredwithjava Basedconfi

Pre-formanceTartuptimeMemoryusage、quarkusandmicronautleadduetocopile-timeprocessingingandgraalvsupport、withquarkusoftentylightbetterine serverlessシナリオ。

パフォーマンス分析ツールを使用してボトルネックを見つけ、開発とテスト段階でVisualVMまたはJProfilerを使用し、生産環境で非同期財産を優先します。 2。オブジェクトの作成を削減し、オブジェクトを再利用し、StringBuilderを使用して文字列のスプライシングを置き換え、適切なGC戦略を選択します。 3.コレクションの使用を最適化し、シーンに応じて初期容量を選択し、プリセットします。 4.同時性を最適化し、同時コレクションを使用し、ロックの粒度を低減し、スレッドプールを合理的に設定します。 5. JVMパラメーターを調整し、合理的なヒープサイズと低遅延のゴミコレクターを設定し、GCログを有効にします。 6.コードレベルでの反射を避け、ラッパークラスを基本タイプに置き換え、初期化を遅延させ、最終と静的を使用します。 7。JMHと組み合わせた連続性能テストと監視

Mavenは、Javaプロジェクト管理と建設の標準ツールです。答えは、POM.xmlを使用してプロジェクト構造、依存関係管理、建設ライフサイクルの自動化、プラグイン拡張機能を標準化するという事実にあります。 1. pom.xmlを使用して、GroupID、artifactid、バージョン、依存関係を定義します。 2。MVNCLEAN、コンパイル、テスト、パッケージ、インストール、展開などのマスターコアコマンド。 3.依存関係管理と除外を使用して、依存関係バージョンと競合を管理します。 4.マルチモジュールプロジェクト構造を通じて大規模なアプリケーションを整理し、親POMによって均一に管理されます。 5。

thejvmenablesjavaの「writeonce、runany where "capabilitybyexcuting byteCodeThethermainComponents:1。theClassLoaderSubSystemloads、links、andinitializes.classfilesusingbootStrap、拡張、およびアプリケーションクラスローロー、
