ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

反射-对比性能分析

2022-06-13 10:31:27  阅读:180  来源: 互联网

标签:反射 程序运行 user1 int 性能 对比 User public


//测试性能分析

public class Main {
    
    //普通方式调用
    public static void test01(){
    
        User user1=new User();
        //第一:创建两个时间,来查看程序运行了多久
        long stsyemTime=Sysetm.currentTimeMillis();//开始时间
        for (int i=0;i<1000000000 ;i++ ){
            user1.getName();//不断获取他的名字
        } 
        
        long endmTime=Sysetm.currentTimeMillis();//开始时间
        //查看用时
        System.out.println("普通方法获取10亿次用时"+(endmTime-stsyemTime)+"ms");
        
    }
    
    //反射方式调用
    //普通方式调用
    public static void test02(){
        User user=new User();
        //通过clss方式获取对象
        Class c1=class.getClass();
        //获取指定名称的方法
        cq.getDeclaredMethod("getName",null);
        //第一:创建两个时间,来查看程序运行了多久
        long stsyemTime=Sysetm.currentTimeMillis();//开始时间
        for (int i=0;i<1000000000 ;i++ ){
           getName.invoke(user,null);
        } 
        
        long endmTime=Sysetm.currentTimeMillis();//开始时间
        //查看用时
        System.out.println("反射方获取10亿次用时"+(endmTime-stsyemTime)+"ms");
        
    }
    
    //关闭安全检查调用
    
    public static void test03(){
        User user=new User();
        //通过clss方式获取对象
        Class c1=class.getClass();
        //获取指定名称的方法
        Method getName=cq.getDeclaredMethod("getName",null);
        //关闭权限检查
        getName.setAccessible(true);
        //第一:创建两个时间,来查看程序运行了多久
        long stsyemTime=Sysetm.currentTimeMillis();//开始时间
        for (int i=0;i<1000000000 ;i++ ){
           getName.invoke(user,null);
        } 
        
        long endmTime=Sysetm.currentTimeMillis();//开始时间
        //查看用时
        System.out.println("关闭检测方法获取10亿次用时"+(endmTime-stsyemTime)+"ms");
        
    }
    
    public static void main(String[] args) {
    test01();
    test02();
    test03();
    }
}

















//实体类:pojo,entity:来表示实体类
class User{
    private String name;
    private int id;
    private int age;
    
    public User(){
        
    }
    
    public User(String name,int id,int age){
        this.name=name;
        this.id=id;
        this.age=age;
    }
    
    
    public void setName(String name){
        this.name=name;
    }
    
    public String getName(){
        return name;
    }
    //------------------
    
     public void setId(int id){
        this.id=id;
    }
    
    public int getId(){
        return id;
    }
    
    //--------------
       public void setAge(int age){
        this.age=age;
    }
    
    public int getAge(){
        return age;
    }
    
    //输出方法
    public String toString(){
        return "User{"+"name="+name+"id="+id+"age="+age+"}";

}
}

 

标签:反射,程序运行,user1,int,性能,对比,User,public
来源: https://www.cnblogs.com/huxingchen/p/16369839.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有