繁体   English   中英

Java反思

[英]Java Reflection

我需要找出一个类是否已经实现了一个特定的接口(假设java.io.Serializable)

以下是我的代码

class Employee{},class Test implements java.io.Serializable{},class Point{},
class Main{}, class MyApp{},class TestApp implements java.io.Serializable{};

class MyMain
{
public static void main(String[] args)
{

String[] classes={"Employee","Test","Point","Main","MyApp"}; // array of class names in default package
Class interFace = Class.forName("java.io.Serializable");

for(int i=0 ;i < classes.length;i++) {

 Class clas = Class.forName(classes[i]);

 boolean match = !clas.isInterface() && !clas.isEnum() && interFace.isAssignableFrom(clas) ;

 if(match )
 {

 System.out.println(classes[i]+ "implements java.io.Serializable");

 }}}}

产量

Employee实现了java.io.Serializable ///错误

测试实现java.io.Serializable ///正确

主要实现java.io.Serializable ///错误

TestApp实现java.io.Serializable ///正确

问题

仅当Employee和Main类位于默认程序包中时,问题才出现。

我不明白为什么会这样?

public class JarFileLoader extends URLClassLoader { 
  public JarFileLoader (URL[] urls) { 
    super (urls); 
  } 
  public void addFile (String path) throws MalformedURLException { 
    String urlPath = "jar:file:/" + path + "!/"; 
    addURL (new URL (urlPath)); 
  } 
}

class JarUtils { 
  public static List getClasseNamesInJAR(String jarName) throws Exception {
    ArrayList classes = new ArrayList();
    try { 
      JarInputStream jarFile = new JarInputStream(new FileInputStream(jarName)); 
      JarEntry jarEntry; 
      while (true) { 
        jarEntry = jarFile.getNextJarEntry(); 
        if (jarEntry == null) 
          break; 
        if (jarEntry.isDirectory()) 
          continue; 
        if ((jarEntry.getName().endsWith(".class"))) {
          classes.add(jarEntry.getName().replaceAll("/", "\\.")); 
        } 
      } 
      return classes; 
    } catch (Exception e) { 
      throw e; 
    } 
  } 
} 

public class ClassImplementer {
  private List getClasses(String path, String interfaceName) throws Exception {
    List list = new ArrayList();

    if (path.endsWith(".jar")) {

       List l = JarUtils.getClasseNamesInJAR(path);
        if(l!=null && l.size()<=0)
            return null;
        try {
            URL urls[] = {};
            JarFileLoader cl = new JarFileLoader(urls);
            cl.addFile(path);
            Class interFace = Class.forName(interfaceName);

            for (int i = 0; i < l.size(); i++) {

                String[] tempClass = l.get(i).toString().split(".class");
                Class clas = cl.loadClass(tempClass[0]);
                boolean match = !clas.isInterface() && !clas.isEnum() && interFace.isAssignableFrom(clas) ;
                if(match ) {
                    list.add(tempClass[0]);
                 }
            }
            return list;
        }
        catch (Exception ex) {
            throw ex;
        }
            return list;
    }
}

public class Test{
public static void main(String[] args)
ClassImplementer imp=new ClassImplementer();
try{
List l=imp.getClasses("c:/abc.jar","java.io.Serializable");
for(int i=0;i<l.size();i++)System.out.println(l.get(i)+" implements java.io.Serializable");
}catch(Exception ex){}
} 

也许您提供了完整的可编译源代码(在哪里捕获异常?),以便您可以在代码中发现错误。

编辑

我看不到明显的东西。 由于其他所有人都有正确的结果-也许您只是处理过时的“ jar”文件? 使用当前版本的测试类删除并重新创建。

您的程序与您的输出不匹配。 当我纠正代码中的错误时,我得到一个输出。

Testimplements java.io.Serializable

这似乎对我的程序是正确的。

假设您粘贴到注释中的代码是您的实际代码,那么问题就在这里:

(来自Inter

for(int i=0;i<l.size();i++){
  String[] t=l.get(i).toString().split(".class");
  Class clas=cl.loadClass(t[0]);
  //                      ^^^^
  boolean m=!clas.isInterface()&&!clas.isEnum()&&iFace.isAssignableFrom(clas);
  if(m)
    list.add(t[0]);
  //         ^^^^
}

t[0]替换为t[i]然后检查错误是否消失。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM