反射

Java反射机制详解

1.什么是反射

反射是java语言中的一种机制,通过机制可以动态的实例化对象,读写属性、调用方法

反射的优点

反射提高了程序的灵活性和扩展性,降低耦合性,提高自适应能力。它允许程序创和控制任何类的对象,无需提前硬编码目标类

反射的缺点

性能问题,使用反射基本上是一种解释操作,用于字段和方法接入时要远慢于直接代码。因此反射机制主要应用在对灵活性和扩展性要求很高的系统框架上,普通程序不建议使用

2. 类类

所有狗 狗类 Dog 狗对象 旺财
所有猫 猫类 Cat 猫对象 肥波
所有类 类类 java.lang.Class 类对象 特定类

java.lang.Class
java.lang.reflect.Method
java.lang.reflect.Field
java.lang.reflect.construct

(Dog.java , Cat.java…).java文件我们能不能描述成一种事物呢?
java.lang.Class这个类就是描述Dog.java,Cat,java这些东西的
具体的.java文件就是描述java.lang.Class这个类的一个具体的实例

类组成部分:
类属性 java.lang.reflect.Field (都是以java面向对象的思想对它进行封装了)
类方法 java.lang.reflect.Method

3.一切反射相关的代码都从获得java.lang.Class类对象开始

3.1 Class.forName(完整类名)
3.2 类名.class
3.3 对象.getClass()

4. 反射三大作用(java.lang.reflect.*)

4.1获取类对象的三种方式

代码演示:
创建一个Student

package com.myy.reflect;

public class Student {
	private String sid;

	private String sname;

	public Integer age;
	
	static{
		System.out.println("加载进jvm中!");
	}

	public Student() {
		super();
		System.out.println("调用无参构造方法创建了一个学生对象");
	}

	public Student(String sid) {
		super();
		this.sid = sid;
		System.out.println("调用带一个参数的构造方法创建了一个学生对象");
	}

	public Student(String sid, String sname) {
		super();
		this.sid = sid;
		this.sname = sname;
		System.out.println("调用带二个参数的构造方法创建了一个学生对象");
	}

	@SuppressWarnings("unused")
	private Student(Integer age) {
		System.out.println("调用Student类私有的构造方法创建一个学生对象");
		this.age = age;
	}

	public String getSid() {
		return sid;
	}

	public void setSid(String sid) {
		this.sid = sid;
	}

	public String getSname() {
		return sname;
	}

	public void setSname(String sname) {
		this.sname = sname;
	}

	public void hello() {
		System.out.println("你好!我是" + this.sname);
	}

	public void hello(String name) {
		System.out.println(name + "你好!我是" + this.sname);
	}

	@SuppressWarnings("unused")
	private Integer add(Integer a, Integer b) {
		return new Integer(a.intValue() + b.intValue());
	}
}

Demo1:

package com.myy.reflect;

/**
 * 获取类对象的方式
 *  通过java提供的反射机制获取到com.myy.reflect.Student.class
 *  1.Class.forName("全路径名");   jdbc/自定义mvc框架调用
 *  2.类名.class 结合泛型做通用分页查询方法会用
 *  3.类java.lang.Class(实例的类)实例(Student.class)的类实例getClass()获取  通用的增删改结合泛型使用
 *  
 * @author myy
 *
 */
public class Demo1 {
  public static void main(String[] args) throws Exception {
//	 1.Class.forName("全路径名");   jdbc/自定义mvc框架调用
	Class stuClz = Class.forName("com.myy.reflect.Student");
	System.out.println("------------");
	
//	 2.类名.class 结合泛型做通用分页查询方法会用
	Class stuClz1 = Student.class;
	System.out.println(stuClz1);
	System.out.println("-------------");
	
	Student stu = new Student();
//	3.类java.lang.Class(实例的类)实例(Student.class)的类实例getClass()获取  通用的增删改结合泛型使用
	Class stuClz2 =  stu.getClass();
	System.out.println(stuClz2);//并且还调用了无参构造器
	
	
}
	
}

运行结果:
在这里插入图片描述

4.2反射实例化对象

代码演示:
Demo2:

package com.myy.reflect;

/**
 * 利用反射进行对象的实例化
 *    之前:通过new关键字进行实例化
 *    现在:通过java.lang.reflect.construct来实例化对象
 *    
 * @author myy
 *
 */
public class Demo2 {
    public static void main(String[] args) throws Exception, Exception {
		Student stu = new Student();
		Class stuClz = stu.getClass();
//		newInstance这个方法默认是使用无参构造器去实例化对象
		Student stu2 = (Student) stuClz.newInstance();
		System.out.println(stu2);//如果不是空就意味着创建出来
	}
}

运行结果:
在这里插入图片描述
提问:假设没有无参构造器运行会不会报错
代码演示:
首先,先把Student类的无参构造器注释掉
在这里插入图片描述
然后,修改一下Demo2的代码

 public static void main(String[] args) throws Exception, Exception {
//		Student stu = new Student();
//		Class stuClz = stu.getClass();
    	Class stuClz = Student.class;
//		newInstance这个方法默认是使用无参构造器去实例化对象
		Student stu2 = (Student) stuClz.newInstance();
		System.out.println(stu2);//如果不是空就意味着创建出来
	}

如图所示运行会报错:
在这里插入图片描述

答:由上面代码演示我们得知当没有无参构造器的时候运行会报错。
运行报错的原因是:没有找到匹配方法,因为它默认找的是默认无参构造器。
注意:一定要提供无参构造器

优势:

  1. 能够对未知的对象进行实例化
  2. 能够对私有的构造器实例化对象

1.1代码演示:

 public static void main(String[] args) throws Exception, Exception {
    	Class stuClz = Student.class;
//		调用有参构造器去实例化对象
    	Constructor<Student> constructor = stuClz.getConstructor(String.class);
    	Student stu2 = (Student)constructor.newInstance("张三");
    	
	}

运行结果:
在这里插入图片描述
1.2代码演示

public static void main(String[] args) throws Exception, Exception {
    	Class stuClz = Student.class;
//		调用有参构造器去实例化对象(两个参数的)
    	Constructor<Student> constructor = stuClz.getConstructor(String.class,String.class);
    	Student stu2 = (Student)constructor.newInstance("t003","张三");
    	
	}

运行结果:
在这里插入图片描述
2.1如果按照以上的操作进行代码演示

 public static void main(String[] args) throws Exception, Exception {
    	Class stuClz = Student.class;
//    	调用私有构造器去实例化对象
    	Constructor<Student> constructor = stuClz.getConstructor(Integer.class);
    	Student stu2 = (Student)constructor.newInstance(18);
    	
	}

运行结果:
在这里插入图片描述
getConstructor与getDeclaredConstructoe的区别
getConstructor只能获取被public修饰的构造器
getDeclaredConstructoe被所有关键字修饰的构造器

所以私有的要用getDeclaredConstructoe

如代码演示:

 public static void main(String[] args) throws Exception, Exception {
    	Class stuClz = Student.class;
//    	调用私有构造器去实例化对象
    	Constructor<Student> constructor = stuClz. stuClz.getDeclaredConstructor(Integer.class);
    	Student stu2 = (Student)constructor.newInstance(18);
    	
	}

运行结果:
在这里插入图片描述

Class com.myy.reflect.Demo2 can not access a member of class com.myy.reflect.Student with modifiers "private"

该错误原因是:找到了私有的构造器,但不能调用因为没有权限

则要对代码进行给予权限如代码演示:

 public static void main(String[] args) throws Exception, Exception {
    	Class stuClz = Student.class;
//    	调用私有构造器去实例化对象
    	Constructor<Student> constructor = stuClz. stuClz.getDeclaredConstructor(Integer.class);
constructor.setAccessible(true);//默认为false    
	Student stu2 = (Student)constructor.newInstance(18);
    	
	}

运行结果:
在这里插入图片描述

4.3 反射动态调用方法

Demo3:
无参的代码演示:

package com.myy.reflect;

import java.lang.reflect.Method;

/**
 * 动态方法调用
 *  构造方法是不是方法
 * 
 * @author myy
 *
 */
public class Demo3 {
 public static void main(String[] args) throws Exception, SecurityException {
	Student stu = new Student();
	Class<? extends Student> stuClz = stu.getClass();//泛型里的上限定
//无参
	Method m= stuClz.getDeclaredMethod("hello");
	m.invoke(stu);
}
}

运行结果:
在这里插入图片描述
有参的代码演示:

public static void main(String[] args) throws Exception, SecurityException {
	Student stu = new Student();
	Class<? extends Student> stuClz = stu.getClass();//泛型里的上限定
	//有参的
	Method m= stuClz.getDeclaredMethod("hello", String.class);
	m.invoke(stu, "张三");
}

运行结果:
在这里插入图片描述
私有的代码演示:

 public static void main(String[] args) throws Exception, SecurityException {
	Student stu = new Student();
	Class<? extends Student> stuClz = stu.getClass();//泛型里的上限定
	//私有的
	Method m = stuClz.getDeclaredMethod("add", Integer.class,Integer.class);
   m.setAccessible(true);
	//	Method.invoke的返回值是被动态调用的方法的返回值
	Object invoke = m.invoke(stu, 11,9);
	System.out.println(invoke);
}

运行结果:
在这里插入图片描述

4.4 反射读写属性

Demo4:
代码演示:

package com.myy.reflect;

import java.lang.reflect.Field;

/**
 * 反射读写属性
 *  自定义标签库,通用分页,自定义mvc也要用
 * @author myy
 *
 */
public class Demo4 {
public static void main(String[] args) throws Exception {
	Student stu = new Student("t003","张三");
	stu.age = 18;
	System.out.println(stu.getSid());
    System.out.println(stu.getSname());	
	Class<? extends Student> stuClz = stu.getClass();
	//私有的
	Field f = stuClz.getDeclaredField("sname");
	f.setAccessible(true);
	System.out.println(f.get(stu));
	
//	获取当前Student实例中的stu私有属性及其属性值
	Field[] fields = stuClz.getDeclaredFields();
	for (Field field : fields) {
		field.setAccessible(true);
		System.out.println(field.getName()+":"+field.get(stu));
	}
}
}

运行结果:
在这里插入图片描述

5.访问修饰符

如何判断类或变量、方法的修饰符,可以使用Java反射机制中,Field的 getModifiers() 方法返回int类型值表示该字段的修饰符,

即这个方法就是返回一个int型的返回值,代表类、成员变量、方法的修饰符。

该修饰符是java.lang.reflect.Modifier的静态属性

对应表如下:
PUBLIC: 1
PRIVATE: 2
PROTECTED: 4
STATIC: 8
FINAL: 16
SYNCHRONIZED: 32
VOLATILE: 64
TRANSIENT: 128
NATIVE: 256
INTERFACE: 512
ABSTRACT: 1024
STRICT: 2048

Modifier提供了很多静态方法,对类和成员访问修饰符进行解码。
如代码演示:

package com.myy.reflect;

import java.lang.reflect.Field;
import java.lang.reflect.Modifier;

/**
 *   Modifier.isAbstract(int mod) 
 *   Modifier.isFinal(int mod) 
 *   Modifier.isInterface(int mod)
 *   Modifier.isNative(int mod)
 *   Modifier.isPrivate(int mod)
 *   Modifier.isProtected(int mod) 
 *   Modifier.isStatic(int mod)
 *   Modifier.isStrict(int mod)
 *   Modifier.isSynchronized(int mod)  
 *   Modifier.isTransient(int mod)
 *   Modifier.isVolatile(int mod) 
 *   
 * @author myy
 *
 */
public class Demo5 {
public static void main(String[] args) {
     Field[] fileds = Student.class.getDeclaredFields();
     for (Field field : fileds) {
		System.out.println(field.getName()+"  访问修饰符是否包括private:"+Modifier.isPrivate(field.getModifiers()));
	    System.out.println(field.getName()+"  访问修饰符是否包括static:"+Modifier.isStatic(field.getModifiers()));
	    System.out.println(field.getName()+"  访问修饰符是否包括public:"+Modifier.isPublic(field.getModifiers()));
     }
}
}

运行结果:
在这里插入图片描述

标题SpringBoot智能在线预约挂号系统研究AI更换标题第1章引言介绍智能在线预约挂号系统的研究背景、意义、国内外研究现状及论文创新点。1.1研究背景与意义阐述智能在线预约挂号系统对提升医疗服务效率的重要性。1.2国内外研究现状分析国内外智能在线预约挂号系统的研究与应用情况。1.3研究方法及创新点概述本文采用的技术路线、研究方法及主要创新点。第2章相关理论总结智能在线预约挂号系统相关理论,包括系统架构、开发技术等。2.1系统架构设计理论介绍系统架构设计的基本原则和常用方法。2.2SpringBoot开发框架理论阐述SpringBoot框架的特点、优势及其在系统开发中的应用。2.3数据库设计与管理理论介绍数据库设计原则、数据模型及数据库管理系统。2.4网络安全与数据保护理论讨论网络安全威胁、数据保护技术及其在系统中的应用。第3章SpringBoot智能在线预约挂号系统设计详细介绍系统的设计方案,包括功能模块划分、数据库设计等。3.1系统功能模块设计划分系统功能模块,如用户管理、挂号管理、医生排班等。3.2数据库设计与实现设计数据库表结构,确定字段类型、主键及外键关系。3.3用户界面设计设计用户友好的界面,提升用户体验。3.4系统安全设计阐述系统安全策略,包括用户认证、数据加密等。第4章系统实现与测试介绍系统的实现过程,包括编码、测试及优化等。4.1系统编码实现采用SpringBoot框架进行系统编码实现。4.2系统测试方法介绍系统测试的方法、步骤及测试用例设计。4.3系统性能测试与分析对系统进行性能测试,分析测试结果并提出优化建议。4.4系统优化与改进根据测试结果对系统进行优化和改进,提升系统性能。第5章研究结果呈现系统实现后的效果,包括功能实现、性能提升等。5.1系统功能实现效果展示系统各功能模块的实现效果,如挂号成功界面等。5.2系统性能提升效果对比优化前后的系统性能
在金融行业中,对信用风险的判断是核心环节之一,其结果对机构的信贷政策和风险控制策略有直接影响。本文将围绕如何借助机器学习方法,尤其是Sklearn工具包,建立用于判断信用状况的预测系统。文中将涵盖逻辑回归、支持向量机等常见方法,并通过实际操作流程进行说明。 一、机器学习基本概念 机器学习属于人工智能的子领域,其基本理念是通过数据自动学习规律,而非依赖人工设定规则。在信贷分析中,该技术可用于挖掘历史数据中的潜在规律,进而对未来的信用表现进行预测。 二、Sklearn工具包概述 Sklearn(Scikit-learn)是Python语言中广泛使用的机器学习模块,提供多种数据处理和建模功能。它简化了数据清洗、特征提取、模型构建、验证与优化等流程,是数据科学项目中的常用工具。 三、逻辑回归模型 逻辑回归是一种常用于分类任务的线性模型,特别适用于二类问题。在信用评估中,该模型可用于判断借款人是否可能违约。其通过逻辑函数将输出映射为0到1之间的概率值,从而表示违约的可能性。 四、支持向量机模型 支持向量机是一种用于监督学习的算法,适用于数据维度高、样本量小的情况。在信用分析中,该方法能够通过寻找最佳分割面,区分违约与非违约客户。通过选用不同核函数,可应对复杂的非线性关系,提升预测精度。 五、数据预处理步骤 在建模前,需对原始数据进行清理与转换,包括处理缺失值、识别异常点、标准化数值、筛选有效特征等。对于信用评分,常见的输入变量包括收入水平、负债比例、信用历史记录、职业稳定性等。预处理有助于减少噪声干扰,增强模型的适应性。 六、模型构建与验证 借助Sklearn,可以将数据集划分为训练集和测试集,并通过交叉验证调整参数以提升模型性能。常用评估指标包括准确率、召回率、F1值以及AUC-ROC曲线。在处理不平衡数据时,更应关注模型的召回率与特异性。 七、集成学习方法 为提升模型预测能力,可采用集成策略,如结合多个模型的预测结果。这有助于降低单一模型的偏差与方差,增强整体预测的稳定性与准确性。 综上,基于机器学习的信用评估系统可通过Sklearn中的多种算法,结合合理的数据处理与模型优化,实现对借款人信用状况的精准判断。在实际应用中,需持续调整模型以适应市场变化,保障预测结果的长期有效性。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值