1つは、メソッドを取得する
- 継承されたメソッドMethodは反映できず、コンパイラによって適用されます。したがって、クラスのメソッドを反映する場合、親クラスのメソッドは考慮されず、現在のクラスのメソッドのみが考慮されます。
1.一般的な方法
- 参照:Methodクラスの一般的なメソッド
- Class.getMethod(String name、Class…parameterTypes);
メソッド名と関連パラメーターに従って、検索して返す必要のあるメソッドオブジェクトを見つけ、parameterTypes:メソッドパラメータータイプのリスト(パラメーターの順序は次のように配置する必要があります)メソッドが宣言されたときにパラメータリストに)
- Class.getMethods();
クラス自体によって宣言されたパブリックメソッド、親クラスのパブリックメソッド、実装されたインターフェイスメソッドを含むすべてのパブリックメソッドを取得します
- Class.getDeclaredMethod(String name、Class ... parameterTypes);
は、このClassオブジェクトによって表されるクラスまたはインターフェイスの指定された宣言済みメソッドを反映するMethodオブジェクトを返します。
- Class.getDeclaredMethods();
クラス自体のメソッド、オーバーライドされた親クラスのメソッド、実装されたインターフェイスメソッドなど、このクラスのすべてのメソッドを取得します
2.テストケース
public class User {
public int id;
private String name;
String address;
protected int sno;
public User() {
}
public User(int id, String name, String address, int sno) {
super();
this.id = id;
this.name = name;
this.address = address;
this.sno = sno;
}
public void study() {
System.out.println("study...");
}
public void eat(int a,String b) {
System.out.println("eat...");
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", address=" + address + ", sno=" + sno + "]";
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((address == null) ? 0 : address.hashCode());
result = prime * result + id;
result = prime * result + ((name == null) ? 0 : name.hashCode());
result = prime * result + sno;
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
User other = (User) obj;
if (address == null) {
if (other.address != null)
return false;
} else if (!address.equals(other.address))
return false;
if (id != other.id)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
if (sno != other.sno)
return false;
return true;
}
}
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
public class Test {
public static void main(String[] args) throws Exception {
Class usrClass = Class.forName("com.lzj.reflect.pojo.User");
Method[] methods = usrClass.getDeclaredMethods();
for(Method method : methods){
System.out.println(Modifier.toString(method.getModifiers()));
System.out.println(method.getReturnType().getSimpleName());
System.out.println(method.getName());
Class[] parameterTypes = method.getParameterTypes();
for(Class parameterType : parameterTypes){
System.out.println(parameterType.getSimpleName());
}
}
}
}
次に、メソッドを逆コンパイルします
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
public class Test {
public static void main(String[] args) throws Exception {
StringBuilder s = new StringBuilder();
Class userClass = Class.forName("com.lzj.reflect.pojo.User");
s.append(Modifier.toString(userClass.getModifiers()) + " class "+userClass.getSimpleName()+" {\n");
Method[] methods = userClass.getDeclaredMethods();
for(Method method : methods){
s.append("\t");
s.append(Modifier.toString(method.getModifiers()));
s.append(" ");
s.append(method.getReturnType().getSimpleName());
s.append(" ");
s.append(method.getName());
s.append("(");
Class[] parameterTypes = method.getParameterTypes();
for(Class parameterType : parameterTypes){
s.append(parameterType.getSimpleName());
s.append(",");
}
if(parameterTypes.length > 0) {
s.deleteCharAt(s.length() - 1);
}
s.append("){}\n");
}
s.append("}");
System.out.println(s);
}
}