A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 冯纪纲 中级黑马   /  2012-10-23 23:08  /  1491 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 冯纪纲 于 2012-10-24 12:17 编辑

这几天自学反射的时候,当看到反射某个类的方法时,突然想起了其中的main函数,它是静态的而且还有一个String的数组参数。反射后用Junit测试的时候出问题了。        

class Person
{
        public static void main(String[] args) {
                System.out.println("main");
                System.out.println(args.length);
        }
}


@Test
        public void test6() throws Exception {
                Person p = new Person();
                Class clazz = Class.forName("com.feng.firstday.Person");//Person是要反射的类,其中有main方法
                Method method = clazz.getMethod("main", String[].class);
                 method.invoke(null, new String[1]);        //就在调用Person类中main函数的时候,为什么指定的参数是一个长度为1的字符数组对象呢?
               //method.invoke(null,new Object[] { new String[] { "aaa", "bbb", "ccc" } });//我又试了一下传进去一个Object对象,然后在里面放一个多个元素的String数组,也               可以?疑惑...

        
        }

评分

参与人数 1技术分 +1 收起 理由
刘芮铭 + 1

查看全部评分

1 个回复

倒序浏览
这个问题需要注意java1.4和1.5版本中invoke方法的不同
1.4中invoke(Object obj, Object [] args)//不支持可变参数
1.5中invoke(Object obj,Object ... args)//支持可变参数
1.5版本的java环境中,如果你调用invoke方法如果你传入了多个参数,使用的可变参数的格式的话invoke(obj,arg1,arg2)那么这个没有一点儿问题的肯定匹配的1.5的invoke方法,不会和1.4的有任何瓜葛;
但是如果你只传入一个参数了,这时候就有说法了,为了保持兼容性,这时候其实就是1.4的invoke方法在起作用,对于一个方法来说不可能都是一个参数的,所以1.4的invoke方法会把你传进来的这个Object [] args参数解包一下,把里面的东西拿出来,然后与方法的各个参数依次匹配;对于你使用的method.invoke(null,new Object[] { new String[] { "aaa", "bbb", "ccc" } });来说最终传给main方法的其实是解包之后的String[] { "aaa", "bbb", "ccc" }--他的类型是与main方法的参数相匹配的所以当然也没问题,但是如果不在String[] { "aaa", "bbb", "ccc" }外面包上一层new Object[]{}的话,就会报错参数个数不对,因为String[] { "aaa", "bbb", "ccc" }解包一层之后是3个参数,而main方法只有一个参数,希望能帮到你。

评分

参与人数 1技术分 +1 收起 理由
刘芮铭 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马