`
反求诸己
  • 浏览: 543297 次
  • 性别: Icon_minigender_1
  • 来自: 湖南娄底
社区版块
存档分类
最新评论

通过反射机制获取位于同一个包下的接口的所有实现类

    博客分类:
  • java
 
阅读更多

public class ClassUtils { 
    public static List<Class> getAllImplClassesByInterface(Class c) { 
 
        // 给一个接口,返回这个接口的所有实现类 
        List<Class> returnClassList = new ArrayList<Class>();// 返回结果 
        // 如果不是一个接口,则不做处理 
        if (c.isInterface()) { 
            String packageName = c.getPackage().getName();// 获得当前包名 
            try { 
                List<Class> allClass = getClassesByPackageName(packageName);// 获得当前包下以及包下的所有类 
                for (int i = 0; i < allClass.size(); i++) { 
                    /**
                     * 判定此 Class 对象所表示的类或接口与指定的 Class 参数cls所表示的类或接口是否相同,
                     * 或是否是其超类或(超)接口,如果是则返回 true,否则返回 false。
                     */
                    if (c.isAssignableFrom(allClass.get(i))) {
                        if (!c.equals(allClass.get(i))) {// 本身加不进去 
                            returnClassList.add(allClass.get(i)); 
                        } 
                    } 
                } 
            } catch (ClassNotFoundException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } catch (IOException e) { 
                // TODO: handle exception 
                e.printStackTrace(); 
            } 
        } 
        return returnClassList; 
 
    } 
 
    // 从一个包中查找出所有类,在jar包中不能查找 
    private static List<Class> getClassesByPackageName(String packageName) throws IOException, ClassNotFoundException { 
        ClassLoader classLoader = Thread.currentThread().getContextClassLoader(); 
        String path = packageName.replace('.', '/'); 
        Enumeration<URL> resources = classLoader.getResources(path); 
        List<File> dirs = new ArrayList<File>(); 
        while (resources.hasMoreElements()) { 
            URL resource = resources.nextElement(); 
            dirs.add(new File(resource.getFile())); 
        } 
        ArrayList<Class> classes = new ArrayList<Class>(); 
        for (File directory : dirs) { 
            classes.addAll(findClasses(directory, packageName)); 
        } 
        return classes; 
    } 
 
    private static List<Class> findClasses(File directory, String packageName) 
            throws ClassNotFoundException { 
        List<Class> classes = new ArrayList<Class>(); 
        if (!directory.exists()) { 
            return classes; 
        } 
        File[] files = directory.listFiles(); 
        for (File file : files) { 
            if (file.isDirectory()) { 
                //递归查找文件夹【即对应的包】下面的所有文件
                assert !file.getName().contains("."); 
                /**
                 * J2SE 1.4在语言上提供了一个新特性,就是assertion(断言)功能,它是该版本在Java语言方面最大的革新。在软件开发中,assertion是一种经典的调试、测试方式。

                    在语法上,为了支持assertion,Java增加了一个关键字assert。它包括两种表达式,分别如下:
                   
                      assert expression1;
                   
                      assert expression1: expression2;
                   
                      在两种表达式中,expression1表示一个boolean表达式,expression2表示一个基本类型或者是一个对象(Object) ,基本类型包括boolean,char,double,float,int和long。由于所有类都为Object的子类,因此这个参数可以用于所有对象。
                   
                      assert
                   
                      如果为true,则程序继续执行。
                   
                      如果为false,则程序抛出AssertionError,并终止执行。
                 */
                classes.addAll(findClasses(file, packageName + '.' + file.getName())); 
            } else if (file.getName().endsWith(".class")) { 
                classes.add(Class.forName(packageName + "." + file.getName().substring(0,file.getName().length() - 6))); 
            } 
        } 
        return classes; 
    }

分享到:
评论

相关推荐

    Java反射机制

    1. **获取类的Class对象**:这是反射操作的第一步,通常可以通过类的`.class`属性、`Class.forName()`方法或者对象的`.getClass()`方法来获取。 2. **获取类的Fields**:使用`Class.getFields()`或`Class....

    java反射机制

    Java反射机制是在运行时通过Reflection APIs获取任何已知类的内部信息,包括类的修饰符(如public、static等)、超类、实现的接口、字段和方法的全部信息。它还允许在运行时改变字段内容、调用方法,甚至创建未知类...

    详细讲解反射机制

    例程10-1的`DumpMethods`类展示了如何使用`Class.forName()`方法加载并初始化一个类,然后通过调用`getDeclaredMethods()`方法获取该类的所有方法信息并打印出来。这个示例简单直观地展示了反射机制的基本用途——...

    JAVA反射机制原理及代码

    Java反射机制是Java语言的一个重要特性,它允许程序在运行时获取关于任何已知类的内部信息,包括类的修饰符、超类、实现的接口,以及字段和方法的所有细节。通过反射,我们可以动态地创建对象、访问私有成员、调用...

    forname实现工程内部反射机制

    总之,通过`Class.forName()`方法,我们可以实现在工程内部的反射机制,动态地访问和操作任何已知类,不论它们位于哪个包中。这为我们的代码提供了更高的灵活性和扩展性,但也需要注意反射可能会带来的安全风险和...

    java反射机制与动态代理

    Java反射机制主要是通过以下几个核心类来实现的,这些类都位于`java.lang.reflect`包中: 1. **`Class`类**:表示一个类,是反射机制的基础。通过它可以获取类的各种信息,如类名、超类、接口、字段、方法等。 2. *...

    Java技术----实现JAVA的动态类载入机制

    通过`Class.forName()`可以获取到一个类的`Class`对象,然后可以进一步创建实例、访问方法和字段。 例如,假设我们有一个名为`com.example.MyClass`的类,我们可以在运行时动态加载它: ```java try { Class&lt;?&gt; ...

    JAVA反射机制与动态代理

    Java反射机制是Java编程语言中一个强大的工具,它允许程序在运行时检查和操作类、接口、字段和方法的信息。通过反射,我们可以在程序执行过程中动态地获取类的信息,包括类的修饰符、超类、实现的接口,以及类的字段...

    Flex 开发类的反射

    1. **定义接口与实现类**:`IPerson`接口定义了`sayHello()`方法,而`PersonImplA`和`PersonImplB`分别实现了这个接口,每个实现类的`sayHello()`方法返回不同的字符串。 2. **反射调用**:在`MainApp`中,使用了`...

    java类加载机制

    在判断两个类是否相等时,必须确保这两个类是由同一个类加载器加载的,否则即使来源于同一个class文件,这两个类也被视为不相等。 ##### 3.1 双亲委派模型 双亲委派模型是Java类加载器的重要特性之一,它的基本...

    java反射.ppt

    Java反射是Java编程语言的一个重要特性,它允许在运行时检查和操作类、接口、字段和方法等对象。反射提供了一种动态访问和修改程序的能力,使得代码可以在不知道具体类的情况下,对对象进行操作。 1. **Class类的...

    java语言反射与动态代理学习笔记

    JDK提供了一系列位于`java.lang.reflect`包中的类来支持反射机制: - **2.1 Class类**:表示一个类的信息,是反射的核心类。通过它可以获取类的各种信息和操作类的实例。 - **2.2 Field类**:表示类的成员变量,...

    Java语言的反射.pdf

    例程10-1中的`DumpMethods`类展示了如何使用反射API获取一个类的所有方法并打印出来。这个类通过`Class.forName()`方法加载指定的类,然后使用`getDeclaredMethods()`方法获取该类声明的所有方法,最后遍历并打印出...

    Java_Reflection_Programming.rar_Agent_java programming_反射

    Java反射编程是Java语言中的一个强大特性,它允许运行时检查类、接口、字段和方法的信息,甚至在没有明确实例化对象的情况下创建和操作对象。这个"Java_Reflection_Programming.rar_Agent_java programming_反射...

Global site tag (gtag.js) - Google Analytics