getInterfaces(),getMethod(String name, Class... parameterTypes),getClass

2024-06-07 06:32

本文主要是介绍getInterfaces(),getMethod(String name, Class... parameterTypes),getClass,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

返回一个 Method 对象,它反映此 Class 对象所表示的类或接口的指定公共成员方法。name 参数是一个String,用于指定所需方法的简称。parameterTypes 参数是按声明顺序标识该方法形式参数类型的 Class 对象的一个数组。如果 parameterTypesnull,则按空数组处理。 


例:以项目Spring_Test为例

beans.xml

<beans><bean id = "u" class = "com.test.dao.impl.UserDAOImpl" /><bean id = "userService" class="com.test.service.UserService" ><property name="userDAO" bean="u"/> </bean>  
</beans>


UserService.java

import com.test.dao.UserDAO;
import com.test.model.User;public class UserService {private UserDAO userDAO;  public void add(User user) {userDAO.save(user);}public UserDAO getUserDAO() {return userDAO;}public void setUserDAO(UserDAO userDAO) {this.userDAO = userDAO;}
}

ClassPathXmlApplicationContext.java

package com.test.spring;import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.List;
import java.util.Map;import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.input.SAXBuilder;public class ClassPathXmlApplicationContext implements BeanFactory {private Map<String , Object> beans = new HashMap<String, Object>();//IOC Inverse of Control DI Dependency Injectionpublic ClassPathXmlApplicationContext() throws Exception {SAXBuilder sb=new SAXBuilder();Document doc=sb.build(this.getClass().getClassLoader().getResourceAsStream("beans.xml")); //构造文档对象Element root=doc.getRootElement(); //获取根元素HDList list=root.getChildren("bean");//取名字为disk的所有元素for(int i=0;i<list.size();i++){Element element=(Element)list.get(i);String id=element.getAttributeValue("id");String clazz=element.getAttributeValue("class");//forName()使用给定的类加载器,返回与带有给定字符串名的类或接口相关联的 Class 对象	       //newInstance()用于创建此 Class 对象所表示的类的一个新实例Object o = Class.forName(clazz).newInstance();//具有指定名的类的 Class 对象。System.out.println(id);System.out.println(clazz);beans.put(id, o);for(Element propertyElement : (List<Element>)element.getChildren("property")) {String name = propertyElement.getAttributeValue("name"); //userDAOString bean = propertyElement.getAttributeValue("bean"); //uObject beanObject = beans.get(bean);//UserDAOImpl instance// "set" + "U" + "serDAO" String methodName = "set" + name.substring(0, 1).toUpperCase() + name.substring(1);System.out.println("name.substring(0, 1)的值为: "+name.substring(0, 1));System.out.println("name.substring(1)的值为: "+name.substring(1));System.out.println("method name = " + methodName);//getClass()返回一个对象的运行时类。Method m = o.getClass().getMethod(methodName, beanObject.getClass().getInterfaces()[0]);//使用使用后一个参数在 前一个参数上指派该对象所表示方法的结果 m.invoke(o, beanObject);}}  }public Object getBean(String id) {return beans.get(id);}
}

     //getClass()返回一个对象的运行时类。
     Method m = o.getClass().getMethod(methodName, beanObject.getClass().getInterfaces()[0]);                                                                                      //使用后一个参数在 前一个参数上指派该对象所表示方法的结果 
     m.invoke(o, beanObject);

o为UserService实例的一个对象  

beanObject为UserDAOImpl类型的对象


Method getMethod(String name, Class<?>... parameterTypes)  
--返回一个 Method 对象,它反映此 Class 对象所表示的类或接口的指定公共成员方法。  

方法后面接收的就是Class类的对象,而如:String.class、int.class这些字节码才是Class类的对象
 

getInterfaces

public Class[] getInterfaces()
确定此对象所表示的类或接口实现的接口。

如果此对象表示一个类,则返回值是一个数组,它包含了表示该类所实现的所有接口的对象。数组中接口对象的顺序与此对象所表示的类的声明的 implements 子句中的接口名顺序一致。例如,给定声明:

 class Shimmer implements FloorWax, DessertTopping { ... }
s 的值为 Shimmer 的一个实例;表达式:
 s.getClass().getInterfaces()[0]
的值为表示 FloorWax 接口的 Class 对象;
 s.getClass().getInterfaces()[1]
的值为表示 DessertTopping 接口的 Class 对象。

如果此对象表示一个接口,则该数组包含表示该接口扩展的所有接口的对象。数组中接口对象的顺序与此对象所表示的接口的声明的 extends 子句中的接口名顺序一致。

如果此对象表示一个不实现任何接口的类或接口,则此方法返回一个长度为 0 的数组。

如果此对象表示一个基本类型或 void,则此方法返回一个长度为 0 的数组。

返回:
该类所实现的接口的一个数组。


按照我的理解简单来说,

//getClass()返回一个对象的运行时类。
 Method m = o.getClass().getMethod(methodName, beanObject.getClass().getInterfaces()[0]);
//使用使用后一个参数在 前一个参数上指派该对象所表示方法的结果 
m.invoke(o, beanObject);

就是调用UserService的setUserDAO方法!!!!!

这篇关于getInterfaces(),getMethod(String name, Class... parameterTypes),getClass的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1038408

相关文章

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

提示:Decompiled.class file,bytecode version如何解决

《提示:Decompiled.classfile,bytecodeversion如何解决》在处理Decompiled.classfile和bytecodeversion问题时,通过修改Maven配... 目录问题原因总结问题1、提示:Decompiled .class file,China编程 bytecode

string字符会调用new分配堆内存吗

gcc的string默认大小是32个字节,字符串小于等于15直接保存在栈上,超过之后才会使用new分配。

类型信息:反射-Class

在说反射前提一个概念:RTTI(在运行时,识别一个对象的类型) public class Shapes {public static void main(String[] args) {List<Shape> shapes = Arrays.asList(new Circle(), new Square(), new Triangle());for (Shape shape : shapes

react笔记 8-17 属性绑定 class绑定 引入图片 循环遍历

1、绑定属性 constructor(){super()this.state={name:"张三",title:'我是一个title'}}render() {return (<div><div>aaaaaaa{this.state.name}<div title={this.state.title}>我是一个title</div></div></div>)} 绑定属性直接使用花括号{}   注

hdu2072(string的应用)

单词数 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 25447    Accepted Submission(s): 5957 Problem Description lily的好朋友xiaoou333最近很空,他

泛型参Class、Class、Class的对比区别

1.原文链接 泛型参Class、Class、Class的对比区别 https://blog.csdn.net/jitianxia68/article/details/73610606 <? extends T>和<? super T> https://www.cnblogs.com/drizzlewithwind/p/6100164.html   2.具体内容: 泛型参数Class、

【UVA】10739 - String to Palindrome(动态规划)

比较水的动态规划 dp[i][j] 将原串 i ~ j 之内的字符转化为回文字符所需要的最小操作次数 其中删除操作和添加操作本质上是一样的。 三个状态转移方程: dp[i][j] = min(dp[i][j] ,dp[i + 1][j]); dp[i][j] = min(dp[i][j] ,dp[i + 1][j - 1]); dp[i][j] = min(dp[i][j] ,dp[

理解String的compareTo()方法返回值

compareTo()的返回值是整型,它是先比较对应字符的大小(ASCII码顺序), 如果第一个字符和参数的第一个字符不等,结束比较,返回他们之间的差值。 如果第一个字符和参数的第一个字符相等,则以第二个字符和参数的第二个字符作比较, 以此类推,直至比较的字符或被比较的字符有一方全比较完,这时就比较字符的长度。 我们可以通过阅读源码加深对compareTo()的理解: comp