Class.forName()和xxx.class

Class.forName()是根据类名称加载类 比如有一个类名为com.abc.AAA 此处Class.forName(‘com.abc.AAA ’).newInstance()就会创建一个AAA对象
.class一般用来获取类的通用属性 比如AAA.class.getDeclareMethod()是获取AAA类的所有声明的方法 主要用于反射机制
.获取私有构造方法

下面为.class获取单列模式中私有构造方法

单列模式--静态内部类

package SingletonDemo;

public class Singleton {
	//单例模式 --静态内部类
	private static class SingletonHolder{
		private static final Singleton  instance = new Singleton();
	}
	private Singleton(){
		System.out.println("单例-- 构造方法 ");
	}
	static{
		System.out.println("静态块");
	}
	public static Singleton getInstance (){
		return SingletonHolder.instance;
	}
}

利用反射机制获取单例模式私有构造方法实例   (所以单例的饿汉、懒汉、双重锁、静态内部类等是要抛开反射机制来说)

获取私有构造方法,需要设置将此对象的 accessible 标志设置为 true,以此来提升反射速度。值为 true 则指示反射的对象在使用时应该取消 Java 语言访问检查。值为 false 则指示反射的对象应该实施 Java 语言访问检查。

如下即:c.setAccessible(true); 

public class ReflectDemo {

	public static void main(String [] args) throws Exception{
		/*以下调用无参的、私有构造函数*/
		Class clazz = Singleton.class;
		Constructor c = clazz.getDeclaredConstructor();
		c.setAccessible(true); //这个方法设置为ture可以调用私有方法
		Singleton singleton = (Singleton) c.newInstance();
	        System.out.println("111111");
		
	}
}
运行结果:   静态块
                单例-- 构造方法 
                111111



public class ReflectDemo {


	public static void main(String [] args) throws Exception{
		/*以下调用无参的、私有构造函数*/
		Class clazz = Singleton.class;
		Constructor c = clazz.getDeclaredConstructor();
		c.setAccessible(true); //这个方法设置为ture可以调用私有方法
		Singleton singleton = (Singleton) c.newInstance();
	    //Class.forName()方式
	   Class clazz2 = Class.forName("SingletonDemo.Singleton");
	   Constructor c2 = clazz2.getDeclaredConstructor();
	   c2.setAccessible(true);
	   
	   Singleton singleton2 = (Singleton) c2.newInstance();
	   boolean clazzBoolean = (clazz == clazz2);
	   System.out.println("clazz == clazz2: "+clazzBoolean);
	   System.out.println("clazz.hashCode(): "+clazz.hashCode());
	   System.out.println("clazz2.hashCode(): "+clazz2.hashCode());
	   boolean singletonBoolean = (singleton == singleton2);
	   System.out.println("singleton == singleton2: "+singletonBoolean);
	   System.out.println();
		
	   //getClass
//	   Class  clazz3 = new Singleton().getClass();
//	   Constructor c3 = clazz3.getDeclaredConstructor();
//	   System.out.println(clazz == clazz2);
	}
}

运行结果:

静态块
单例-- 构造方法 
单例-- 构造方法 
clazz == clazz2: true
clazz.hashCode(): 115344161
clazz2.hashCode(): 115344161

singleton == singleton2: false

从结果可以看出,获取的Class的对象是同一个,目标类的实例对象不一样

第三种方法getClass我还没找到正确用法,编译通不过,待后续完善

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值