最近、常に学習にあまり意図を感じるので、彼は学習計画を策定し、それらが記録するブログの方法を記述することで学んだことを学習の計画プロセスは、今日は初日学習プログラムであり、我々は自分自身を与えることができるように願っていますそれは良いスタートを予定しています。
今日の学習内容は、内省的な技術です。
A.イントロスペクション(Introspectorの)
イントロスペクションAPI、JDK JavaBeanの動作の集合である反射ベースの技術です。
- JavaBeanプロパティの計算方法
のIntrospectorの通過JavaBeanクラスに関する情報を取得するため
のBeanInfoによって記述子(getMethodDescriptors())と属性記述子(getPropertyDescriptorsが())を取得するためのメソッド
getPropertyDescriptorsが()によって、我々はBeanクラスの属性を取得することができます
ので、は、最初の我々はペロンを作成しますカテゴリ
public class Person {
private String name;
private String city;
private String hobby;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
public String getHobby() {
return hobby;
}
public void setHobby(String hobby) {
this.hobby = hobby;
}
}
次に、クラス記述子および配列の印刷長さの結果として得られる特性は、アレイは4の長さを見つける、Personクラスは、3属性
@Test
public void demo1() {
// 通过Introspector获得BeanInfo信息
try {
BeanInfo beanInfo = Introspector.getBeanInfo(Person.class);
// 获得所有JavaBean的属性描述器
//每一个属性描述器代表JavaBean的一个属性
PropertyDescriptor[] propertyDescriptors = beanInfo
.getPropertyDescriptors();
//计算JavaBean的属性
System.out.println(propertyDescriptors.length);
} catch (IntrospectionException e) {
e.printStackTrace();
}
}
だから、ここでは、JavaBeanプロパティは、メンバ変数によって計算しますが、getおよびsetメソッドによって計算されていない、ということであるに注意すること
など:
あなたはメソッドのgetNameを(持っています)、それは取り除く名を取得すると、名前の最初の文字を小文字になりますプロパティ
、メソッドgetAgeを(持っている)、それはRID年齢は最初の文字を小文字の年齢属性を取得します取得します
。この計算を。
この時、彼らは疑問を持っている、そしてそれはこの計算方法によれば、取得し、唯一の3つのメソッドを設定するには、算出したプロパティは、3つしかなければなりませんああ、私たちは、プロパティ記述子とプリントの名前を通過することができます
@Test
public void demo1() {
// 通过Introspector获得BeanInfo信息
try {
BeanInfo beanInfo = Introspector.getBeanInfo(Person.class);
// 获得所有JavaBean的属性描述器
//每一个属性描述器代表JavaBean的一个属性
PropertyDescriptor[] propertyDescriptors = beanInfo
.getPropertyDescriptors();
//计算JavaBean的属性
System.out.println(propertyDescriptors.length);
//遍历
for(PropertyDescriptor prDescriptor : propertyDescriptors){
System.out.println(prDescriptor.getName());
}
} catch (IntrospectionException e) {
e.printStackTrace();
}
}
得られた結果は以下のとおりです。
第4コンソールの印刷属性クラスを見つけて、Personクラスで発見されていません。本来、すべてのオブジェクトは、問題が解決される第4のクラスの属性、その結果、計算方法のJavaBeanプロパティによれば、方法はgetClass Objectオブジェクトを継承オブジェクトクラスから継承します。
どのような影響最後にその内省?それはそれの意味は何であるのか?(地図は、対応するオブジェクトのプロパティの値を保持します)実証するためのケーススタディを通して:
@Test
public void demo2() {
// 将Map的值保存到相应的对象属性中
Map<String, String> map = new HashMap<String, String>();
map.put("name", "mary");
map.put("city", "北京");
map.put("hobby", "music");
Person person = new Person();
//保存数据
saveMapValueToObject(map, person);
System.out.println(person.getName());
System.out.println(person.getCity());
System.out.println(person.getHobby());
}
// 将Map中的key与Object中的属性进行匹配,将Map对应的value保存至Object的属性中
private void saveMapValueToObject(Map<String, String> map, Object obj) {
try {
// 内省获得Javab的信息
BeanInfo beanInfo = Introspector.getBeanInfo(obj.getClass());
// 通过beanInfo获得所有属性
PropertyDescriptor[] propertyDescriptors = beanInfo
.getPropertyDescriptors();
// 遍历每一个属性
for (PropertyDescriptor pDescriptor : propertyDescriptors) {
// 用属性去Map中寻找对应的key
String name = pDescriptor.getName();
if (map.containsKey(name)) {// 属性在Map中存在对应的key
String value = map.get(name);
// 通过属性描述器,获得写入该属性的方法
Method setMethod = pDescriptor.getWriteMethod();
// 利用反射设置value
setMethod.invoke(obj, value);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
コンソールは、Personクラスの対応するプロパティに保存されて成功裏に設定されている情報、データマップを通じて知ることができ、ケースは内省的な技術であるアプリケーションです。
JSPアクションでその命令である知っている必要があります