前面写了篇文章讲了java对象的四种创建方式,其中的java反射只是提了一下,但是很多细节没有说,这篇文章就专门说一说java反射的一些实现。
首先创建源类:
package day01;
import javax.security.auth.login.LoginContext;
public class User {
private String username;
private String password;
public User() {}
public User(String username,String password) {
this.username=username;
this.password=password;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "User [username=" + username + ", password=" + password + "]";
}
public void Login() {
System.out.println(username+"的密码是"+password);
}
}
然后在主类中获取类的对象:
//方式1:
//Class<User> user=User.class;
//方式2:
//Class user=new User().getClass();
//方式3:
//Class user=Class.forName("day01.User");
//方式4:
Class clazz=Thread.currentThread().getContextClassLoader().loadClass("day01.User");
然后实例化对象:
//方式1:
User user=new User();
//方式2:
//User user=(User)Class.forName("day01.User").newInstance();
//方式3:
//Constructor cons = clazz.getDeclaredConstructor((Class[]) null);
//User user = (User) cons.newInstance();
//System.out.println(user);
给方法的参数赋值(public):
Method setUsername = clazz.getMethod("setUsername", String.class);
setUsername.invoke(user, "gangan");
检验是否赋值成功:
user.Login();
最后成功打印出结果:
这里我们发现,我们的构造方法也好,成员方法也好都是public权限,那么对于private这类权限怎么处理的呢?
我们就需要取消检查。这里我们在User中修改:
private void Login(String username) {
System.out.println(username+"的密码是"+password);
}
利用setAccessible()方法来取消权限检查
Class clazz=Class.forName("day01.User");
Method setUsername = clazz.getDeclaredMethod("Login", String.class);
setUsername.setAccessible(true);
setUsername.invoke(user, "gangan");
通过invoke()自动调用Login()私有方法,最终成功打印结果,如上图。