一道关于getMethod的编程题,请高手赐招!

问题描述

在默认包下,有若干个独立的,已经编译好的".class"文件。这些文件的类有两个共同特点:它们的名字都是"D+数字"的形式,例如,D1,D123,等等。这些类都有一个类似的方法(name可变):public Integer name(Integer a, Integer b)其功能是将输入的a和b经过函数处理,得到另外一个Integer类型的数据后返回。你的任务是编写一个程序,该程序的功能是创建一个新的类Abc,实现它的静态方法是:public static int Abc(int input1,int input2, int output, String methodName, int from, int to)其中,input1表示第一个参数,input2表示第二个参数,output表示输出值。methodName表示方法的名称,from是类名后面数字的起始序号,to是类名后面数字的终止序号。该方法要统计出默认包下有多少程序符合类和方法的命名要求,对输入input1和input2能够正确输出output值(当然都是相应的Integer)提示1:例如,假设默认包下有如下4个程序编译生成的.class文件:public class D1{ public Integer add(Integer a, Integer b){ return a.intValue()+b.intValue()+1;}}public class D5{ public Integer add(Integer a, Integer b){ return a.intValue()+b.intValue();}}public class D6{ public Integer add(Integer a, Integer b){ int result=a.intValue()+b.intValue();result++;return result;}}public class D11{pubic Integer adding(Integer a, Integer b){ return a.intValue()+b.intValue();}}你编写的程序运行后,如果方法Abc的参数值input1为1,input2为6,output为8,methodName为"add",from为1, to 为15,则对默认包下的上述4个程序,你编写的方法返回值勤应该是2,因为只有D1,D6完全符合要求并且正确,而程序D5和D11不正确,因为D5的结果错误,D11的函数"adding"名字与输入函数名"add"不符。这就是说,默认包下有几个完全符合要求并且正确的程序,你的方法就返回几。提示2:编写该程序主要用到类Class,这个类中的如下几个方法对编写该程序有用:(1) public static Class forName(String className) throws ClassNotFoundException(2)public Object newInstance() throws InstantionException, IllegalAccessException(3)public Method getMethod(String name, Class[] parameterTypes)throws NoSuchMethodException, SecurityException

解决方案

看看这样的是否符合要求。。。public static int Abc(int input1, int input2, int output,String methodName, int from, int to) {int count = 0;String prefix = "D";for(int i=from; i<=to; i++) {try {Class clazz = Class.forName(prefix + i);Object instance = clazz.newInstance();Method method = clazz.getDeclaredMethod(methodName, Integer.class, Integer.class);Integer res = (Integer)method.invoke(instance, input1, input2);if(res == output) {count++;System.out.println("pick " + prefix + i);}} catch (Exception e) {}}return count;}
解决方案二:
可以写一个接口 interface DInter{ public Integer add(Integer a, Integer b) ;}中间可以写一个类DImpl implements DInter{ public Integer add(Integer a, Integer b) { return a.intValue()+b.intValue(); }}然后D1,D2,D3,D4...继承DImpl ,如果算法需要改变的话,就覆盖add方法。

时间: 2024-07-29 20:58:16

一道关于getMethod的编程题,请高手赐招!的相关文章

ea编程-一道经典的EA编程题,你想挑战吗?

问题描述 一道经典的EA编程题,你想挑战吗? EA编程内容 品种:直盘外汇 时间周期:日线 入场信号做多: 条件1:当这个K线的收盘价高于左边第四根最高价时(以当下K线为参考从右往左数到第四根K线),收盘之后换线出现新K线. 分批建仓: A 换线之后立马开仓,建仓为0.2手. B,当换线后的K线回撤到前一根K线的1/2处,再次建仓为0.2手.(紧邻两根K线,以换线后这根K线为1,前一根K线为2,仅有当1这个K线回撤到2K线的1半才加仓,后市任何一根K线都不成立) C,当换线K线回撤到前一根K线的

一道关于二叉树的编程题

问题描述 一道关于二叉树的编程题 给出一组整数对 { (a[0], b[0]), (a[1], b[1]) ... (a[n-1], b[n-1]) },所有 a 值 和 b 值分别不重复(任意 i != j 满足 a[i] != a[j] 且 b[i] != b[j]).构造一棵 n 结点的二叉树,将这 n 个整数对分配到各个结点上.根和所有子树满足以下条件: 1) 所有结点的 a 值满足二叉查找树的顺序,即 left->a < root->a && root->

如何提高ASP.NET 编程能力???请高手指教!!!!

问题描述 如何提高ASP.NET编程能力???请高手指教!!!!最好能写出学习步骤和方法,谢谢!!!本人目前的水平属于中低水平,只能开发简单的系统,而且不规范. 解决方案 解决方案二:严格来说,我俩不算中低水平,只能算在入门.呵呵~~~个人觉得,最快最有效的方法是:参加培训+找项目做(跟别人一起做)+多看书(上CSDN)解决方案三:1看书,C#高级编程,设计模式2实践AJAX,LINQ,WCF3系统开发解决方案四:能具体点么?最好有高手的自己的心得体会!!!是如何一步步进步的!!!解决方案五:引

WINFORM应用,如何实现等待子线程结束的同时,主界面UI不卡,请高手出招,在线等..............

问题描述 WINFORM应用,如何实现等待子线程结束的同时,主界面UI不卡,请高手出招,在线等..............业务描述有以下耗时业务队列需要按顺序完成UI界面有按钮M,点击M,在处理函数YY中,需要执行以下任务队列{执行耗时业务A(提交给到线程)等待A完成处理结果执行耗时业务B(提交给到线程)等待B完成处理结果执行耗时业务c(提交给到线程)等待c完成处理结果...........}问题:在等待线程N结束的过程中,如何实现不卡UI?如果在函数YY中,直接使用ManualResetEve

请高手支招org.springframework.beans.factory.BeanCreationException

问题描述 Errorcreatingbeanwithname'sessionFactory'definedinServletContextresource[/WEB-INF/applicationContext.xml]:Invocationofinitmethodfailed;nestedexceptionisorg.hibernate.HibernateException:HibernateDialectmustbeexplicitlysetatorg.springframework.bea

如何终止事件继续执行,在线等,请高手支招............

问题描述 在按钮事件处理中有以下逻辑要顺序执行voidbtnCancle_Click(objectsender,EventArgse){业务1业务2--..业务N}"业务1"到"业务N"都非常耗时需求是:点击界面上的另一个"终止"按钮,事件处理函数voidbtnCancle_Click(objectsender,EventArgse)可以在任意业务m(1<=m<N)执行结束后,终止后面的业务m+1执行,业务N开始执行后,忽略"

高手赐招 网页制作经典技巧23条

提示:使用前请把大写状态下"<>"改为小写状态下的"<>" 01.让背景图不滚动 IE浏览器支持一个 Body 属性 bgproperties,它可以让背景不滚动: 〈Body Background="图片文件" bgproperties="fixed"〉 02.让你的网页无法另存为 <noscript><iframe src=http:///htmldata/2005-12-26/*

求高手赐招,有关多变查询后的数据在JSP页面显示的问题?

问题描述 我有三四张表:User表.Car表.Account表和AccountTrade表,四张表分别对应四个entity类和ORM映射文件.User表:userid,username...Car表:carid,carNo(车牌号)...Account表:accountid,accountNo,userid,carid...AccountTrade表(交易流水表):accountid,increaseNo(每个账号有多条流水信息,increaseNo最大的为最新的交易记录),accountBal

树-一道编程题,用c++编程,求助

问题描述 一道编程题,用c++编程,求助 给定一颗无根树,假设它有n个节点,节点编号从1到n,求任意两点之间的距离之和,也就是求任意一点到其它点的距离之和,边长都为1.要求时间复杂度为O(n) 解决方案 先做一遍DFS求出所有节点到根节点的距离之和,然后可以发现,如果知道到一个点的距离之和,可以用O(1)求出所有节点到它相邻点的距离之和 解决方案二: /* ***********************************************Author :xdloveCreated T