Java,静态和动态语言,反射机制,实例化对象、访问属性和方法
yuyutoo 2024-10-12 00:56 4 浏览 0 评论
静态语言和动态语言
动态语言,在运行时可以改变其结构的语言,主要的动态语言有:JavaScript、Python、Object-C、C#。
静态语言,在运行时不可以变其结构的语言,主要有:C、C++、Java。
Java不是动态语言,但可以称之为“准动态语言”,即:Java有一定的动态性,利用Java反射机制获得类似动态语言的特性,让写程序时更加灵活。
Java反射(Reflection)
Reflection(反射)是Java被视为动态语言的关键,反射机制允许程序在执行期借助于:Reflection API取得任何类的内部信息,并能直接操作任意对象的内部属性及方法。
JVM加载完类之后,在堆内存的方法区(元数据区)会产生一个Class类型的对象(一个类有且只有一个Class对象),这个对象包含了完整的类的结构信息,通过这个对象可以创建一个或者多个实例对象。
优点VS缺点
优点:可以实现动态创建对象和编译,体现出很大的灵活性。
缺点:对性能有影响,使用反射基本上是一种解释型操作,这类操作效率低于直接执行相同的操作。
反射机制主要提供的功能:
1、在运行时判断任意一个对象所属的类;2、在运行时构造任意一个类的对象;3、在运行时判断任意一个类所具有的成员变量和方法;4、在运行时调用任意一个对象的方法;5、生成动态代理。
反射相关的主要API:
1、java.lang.Class: 代表一个类。
2、java.lang.reflect.Constructor: 代表类的构造器。
3、java.lang.reflect.Field: 代表类的成员变量。
4、java.lang.reflect.Method: 代表类的方法。
代码案例
package com.what21.demo.demo10;
import lombok.Data;
import java.util.Date;
@Data
public class User {
private Integer id;
private String name;
private int age;
String email;
protected String phone;
public String desc;
public Date createTime;
public User() {
this.createTime = new Date();
}
public User(Integer id, String name) {
this.id = id;
this.name = name;
this.createTime = new Date();
}
public User(Integer id, String name, int age) {
this.id = id;
this.name = name;
this.age = age;
this.createTime = new Date();
}
}
Java反射机制,构造方法:
import java.lang.reflect.Constructor;
/**
* Java反射机制
*/
public class ReflectionTest01 {
/**
* @param args
*/
public static void main(String[] args) throws Exception {
String className = "com.what21.demo.demo10.User";
reflectConstructor(className);
reflectDeclaredConstructor(className);
}
/**
* 反射构造方法
*
* @param className
* @throws Exception
*/
public static void reflectConstructor(String className) throws Exception {
// 构造方法信息
Class<?> clazz = Class.forName(className);
System.out.println("------------------------------------------------------------");
Constructor<?>[] constructors = clazz.getConstructors();
System.out.println("构造方法的数量为: " + constructors.length);
for (Constructor<?> constructor : constructors) {
Class<?>[] paramClazzs = constructor.getParameterTypes();
System.out.print("构造方法的参数个数: " + paramClazzs.length + " ");
System.out.print("构造方法的参数类型: ");
for (Class<?> paramClazz : paramClazzs) {
System.out.print(paramClazz.getName() + " ");
}
System.out.println();
}
System.out.println("------------------------------------------------------------");
// 调用public修饰符修饰的构造方法
Constructor<?> threeParam = clazz.getConstructor(Integer.class, String.class, int.class);
Object object = threeParam.newInstance(1001, "张三", 25);
System.out.println("根据构造方法创建对象:" + object);
}
/**
* 反射声明的构造方法
*/
public static void reflectDeclaredConstructor(String className) throws Exception {
// 构造方法信息
Class<?> clazz = Class.forName(className);
System.out.println("------------------------------------------------------------");
Constructor<?>[] constructors = clazz.getDeclaredConstructors();
System.out.println("构造方法的数量为: " + constructors.length);
for (Constructor<?> constructor : constructors) {
Class<?>[] paramClazzs = constructor.getParameterTypes();
System.out.print("构造方法的参数个数: " + paramClazzs.length + " ");
System.out.print("构造方法的参数类型: ");
for (Class<?> paramClazz : paramClazzs) {
System.out.print(paramClazz.getName() + " ");
}
System.out.println();
}
System.out.println("------------------------------------------------------------");
// 调用没有修饰符修饰的构造方法
Constructor<?> zeroParam = clazz.getDeclaredConstructor();
Object zeroParamObj = zeroParam.newInstance();
System.out.println("根据构造方法创建对象:" + zeroParamObj);
// 调用protected修饰符修饰的构造方法
Constructor<?> towParam = clazz.getDeclaredConstructor(Integer.class, String.class);
Object towParamObj = towParam.newInstance(1001, "张三");
System.out.println("根据构造方法创建对象:" + towParamObj);
// 调用public修饰符修饰的构造方法
Constructor<?> threeParam = clazz.getDeclaredConstructor(Integer.class, String.class, int.class);
Object object = threeParam.newInstance(1002, "李四", 25);
System.out.println("根据构造方法创建对象:" + object);
System.out.println("------------------------------------------------------------");
}
}
Java反射机制,操作属性:
import java.lang.reflect.Field;
import java.util.Date;
/**
* Java反射机制
*/
public class ReflectionTest02 {
/**
* @param args
*/
public static void main(String[] args) throws Exception {
String className = "com.what21.demo.demo10.User";
reflectFiled(className);
reflectDeclaredFiled(className);
}
/**
* 反射声明的类属性
*/
public static void reflectFiled(String className) throws Exception {
// 属性信息
Class<?> clazz = Class.forName(className);
System.out.println("------------------------------------------------------------");
Field[] fields = clazz.getFields();
System.out.println("属性的个数为: " + fields.length);
for (Field field : fields) {
System.out.println("属性的类型: " + field.getType() + " 属性的名称:" + field.getName());
}
Object object = clazz.newInstance();
// 赋值并输出父类public修饰的属性
Field superField = clazz.getField("createTime");
superField.setAccessible(true);
superField.set(object, new Date());
System.out.println(superField.get(object));
// 赋值并输出public修饰的属性
Field field = clazz.getField("desc");
field.setAccessible(true);
field.set(object, "描述");
System.out.println(field.get(object));
}
/**
* 反射声明类属性
*/
public static void reflectDeclaredFiled(String className) throws Exception {
// 属性信息
Class<?> clazz = Class.forName(className);
System.out.println("------------------------------------------------------------");
Field[] fields = clazz.getDeclaredFields();
System.out.println("属性的个数为: " + fields.length);
for (Field field : fields) {
System.out.println("属性的类型: " + field.getType() + " 属性的名称:" + field.getName());
}
Object object = clazz.newInstance();
// 赋值并输出没有修饰符修饰的属性
Field defaultField = clazz.getDeclaredField("email");
defaultField.setAccessible(true);
defaultField.set(object, "demo@what21.com");
System.out.println("email=" + defaultField.get(object));
// 赋值并输出protected修饰的属性
Field protectedField = clazz.getDeclaredField("phone");
protectedField.setAccessible(true);
protectedField.set(object, "13800000000");
System.out.println("phone=" + protectedField.get(object));
// 赋值并输出public修饰的属性
Field field = clazz.getDeclaredField("desc");
field.setAccessible(true);
field.set(object, "描述");
System.out.println("desc=" + field.get(object));
System.out.println("------------------------------------------------------------");
}
}
Java反射机制,操作方法:
import java.lang.reflect.Method;
import java.util.Date;
/**
* Java反射机制
*/
public class ReflectionTest03 {
/**
* @param args
*/
public static void main(String[] args) throws Exception {
String className = "com.what21.demo.demo10.User";
reflectMethod(className);
reflectDeclaredMethod(className);
}
/**
* 反射方法
*
* @param className
* @throws Exception
*/
public static void reflectMethod(String className) throws Exception {
// 属性信息
Class<?> clazz = Class.forName(className);
Method[] mothods = clazz.getMethods();
for (Method method : mothods) {
System.out.print("方法的名称: " + method.getName() + ",属性的返回值类型:" + method.getReturnType() + " ");
Class<?>[] paramClazzs = method.getParameterTypes();
System.out.print("方法的参数个数: " + paramClazzs.length + " ");
for (Class<?> paramClazz : paramClazzs) {
System.out.print(paramClazz.getName() + " ");
}
System.out.println();
}
Object object = clazz.newInstance();
// 调用父类public修饰的方法
Method superSetMethod = clazz.getMethod("setCreateTime", Date.class);
superSetMethod.invoke(object, new Date());
Method superGetMethod = clazz.getMethod("getCreateTime");
System.out.println(superGetMethod.invoke(object));
// 调用public修饰的方法
Method setMethod = clazz.getMethod("setDesc", String.class);
setMethod.invoke(object, "描述");
Method getMethod = clazz.getMethod("getDesc");
System.out.println("getDesc()=" + getMethod.invoke(object));
}
/**
* 反射声明的方法
*
* @param className
* @throws Exception
*/
public static void reflectDeclaredMethod(String className) throws Exception {
// 属性信息
Class<?> clazz = Class.forName(className);
Method[] mothods = clazz.getDeclaredMethods();
for (Method method : mothods) {
System.out.print("方法的名称: " + method.getName() + ",属性的返回值类型:" + method.getReturnType() + " ");
Class<?>[] paramClazzs = method.getParameterTypes();
System.out.print("方法的参数个数: " + paramClazzs.length + " ");
for (Class<?> paramClazz : paramClazzs) {
System.out.print(paramClazz.getName() + " ");
}
System.out.println();
}
Object object = clazz.newInstance();
// 调用没有修饰符修饰的方法
Method defaultSetMethod = clazz.getDeclaredMethod("setEmail", String.class);
defaultSetMethod.setAccessible(true);
defaultSetMethod.invoke(object, "demo@what21.com");
Method defaultGetMethod = clazz.getDeclaredMethod("getEmail");
System.out.println("getEmail()=" + defaultGetMethod.invoke(object));
// 调用protected修饰的方法
Method protectedSetMethod = clazz.getDeclaredMethod("setPhone", String.class);
protectedSetMethod.setAccessible(true);
protectedSetMethod.invoke(object, "13800000000");
Method protectedGetMethod = clazz.getDeclaredMethod("getPhone");
System.out.println("getPhone()=" + protectedGetMethod.invoke(object));
// 调用public修饰的方法
Method publicSetMethod = clazz.getMethod("setDesc", String.class);
publicSetMethod.invoke(object, "描述");
Method publicGetMethod = clazz.getMethod("getDesc");
System.out.println("getDesc()=" + publicGetMethod.invoke(object));
}
}
相关推荐
- 网站建设:从新手到高手
-
现代化网站应用领域非常广泛,从个人形象网站展示、企业商业网站运作、到政府公益等服务网站,各行各业都需要网站建设。大体上可以归结四类:宣传型网站设计、产品型网站制作、电子商务型网站建设、定制型功能网站开...
- JetBrains 推出全新 AI 编程工具 Junie,助力高效开发
-
JetBrains宣布推出名为Junie的全新AI编程工具。这款工具不仅能执行简单的代码生成与检查任务,还能应对编写测试、验证结果等复杂项目,为开发者提供全方位支持。根据SWEBench...
- AI也能写代码!代码生成、代码补全、注释生成、代码翻译轻松搞定
-
清华GLM技术团队打造的多语言代码生成模型CodeGeeX近期更新了新的开源版本「CodeGeeX2-6B」。CodeGeeX2是多语言代码生成模型CodeGeeX的第二代模型,不同于一代CodeG...
- 一键生成前后端代码,一个36k星的企业级低代码平台
-
「企业级低代码平台」前后端分离架构SpringBoot2.x,SpringCloud,AntDesign&Vue,Mybatis,Shiro,JWT。强大的代码生成器让前后端代码一键生成,无需写任...
- Gitee 代码托管实战指南:5 步完成本地项目云端同步(附避坑要点)
-
核心流程拆解:远程仓库的搭建登录Gitee官网(注册账号比较简单,大家自行操作),点击“新建仓库”,建议勾选“初始化仓库”和“设置模板文件”(如.gitignore),避免上传临时文件。...
- jeecg-boot 源码项目-强烈推荐使用
-
JEECGBOOT低代码开发平台...
- JetBrains推出全新AI编程工具Junie,强调以开发者为中心
-
IT之家2月1日消息,JetBrains发文,宣布推出一款名为Junie的全新AI编程工具,官方声称这款AI工具既能执行简单的代码生成与检查等基础任务,也能应对“编写测试、验证结...
- JetBrains旗下WebStorm和Rider现已加入“非商用免费”阵营
-
IT之家10月25日消息,软件开发商JetBrains今日宣布,旗下WebStorm(JavaScript开发工具)和Rider(.NET开发工具)现已加入“非商用免费”阵营。如果...
- 谈谈websocket跨域
-
了解websocketwebsocket是HTML5的新特性,在客户端和服务端提供了一个基于TCP连接的双向通道。...
- websocket调试工具
-
...
- 利用webSocket实现消息的实时推送
-
1.什么是webSocketwebSocket实现实现推送消息WebSocket是HTML5开始提供的一种在单个TCP连接上进行全双工通讯的协议。以前的推送技术使用Ajax轮询,浏览器需...
- 为 Go 开发的 WebSocket 库
-
#记录我的2024#...
- 「Java基础」Springboot+Websocket的实现后端数据实时推送
-
这篇文章主要就是实现这个功能,只演示一个基本的案例。使用的是websocket技术。...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)